logo
为了能更好地了解您的商业使用需求,请参与 Ant Design Blazor 商业应用调查,一起建设商业应用社区,为企业系统研发赋能!

成员路径助手

提供 PathHelper 通过成员路径字符串来读写对象成员值。

  • 支持Property和Field,支持取值操作和赋值操作。
  • ⚠ 重要变化:因为字符串中使用双引号时需要转义,现在改为使用单引号来表示字符串索引键。

支持的操作

1. 访问后代成员

例:obj.PathGet("A.B.C")

2. 数组模式索引,以及实现了 Count 属性和 get_Item(int) (即 this[int] 方法的 类似 List 的 类型

例:obj.PathGet<string>("A.B[1].C")

3. 字典模式索引,以及实现了 ContainsKey 方法和 get_Item (即 this[key]) 方法的 类似 Dictionary 的 类型。

例:obj.PathGetDefault<int?>("A.B['test'].C")。 对象不存在时返回 null 例:obj.PathGetDefault<int>("A.B['test'].C")。 对象不存在时返回 default(int)

4. 数组、字典嵌套

例:obj.PathGet("A.B['test'][3].C")obj.PathGet("A.B[1][5].C")obj.PathGet("A.B[1]['user id'].C")

5. 成员赋值

⚠ 注意:使用赋值操作时,路径只支持类属性类字段值类型字段,如果存在值类型属性,则无法赋值,执行结果是原值保持不变。

例: obj.PathSet("A.B['test']", "test value"), 则 obj.PathGet("A.B['test']") == "test value"true 例: obj.PathSet("A.C", "abcde"), 则 obj.PathGet<string>("A.C") == "abcde"true

6. 非空模式和可空模式

6.1. 非空模式

⚠ 注意:非空模式下需要开发者保证属性路径上的属性不为null,如果包含数组模式或字典模式,还需要保证索引对象必须存在,否则访问不存在的对象的属性时会抛出异常。

当结果数据类型是值类型且不是Nullable时(如int),会生成直接访问表达式,如果属性路径中存在Nullable类型,会不做null检查直接访问。

如:访问属性A.B.C 时,其中 BNullable<MyStruct>,会生成类似 A.B!.Value.C 的表达式。

对于数组或字典,会直接访问,如:访问数组对象属性 A.B[i].C 时,不会检查 B[i] 是否存在。访问字典对象属性 A.D["my data"].C 时,不会检查 D["my data"] 是否存在。

6.2. 可空模式

可空模式下不需要保证数据不为null,也不用保证数组模式或字典模式必定有值,访问到不存在对象的属性时会返回null。

当结果数据类型是Nullable值类型或class时(如int?, string),会生成条件表达式,如果属性路径中存在Nullable或class类型,会先检查非null再访问,遇到null对象会返回null。

如:访问属性 A.B.C 时,其中 BNullable<MyStruct>,会生成类似 if(A != null && A.B.HasValue) 的检查表达式。

对于数组或字典,会先检查再访问,如:访问数组对象属性 A.B[i].C 时,会检查 i < B.Count && i >= 0 , 结果是 false 时返回 default(T)。访问字典对象属性 A.D["my data"].C 时,会检查 D.ContainsKey("my data"), 结果是 false 时返回 default(T)

API

三种泛型用法:

  1. <T,V> : 用于对象和返回值(赋值)都可以得到泛型参数的场景。
  2. <object, V> : 用于可得到对象泛型参数,得不到返回值(赋值)泛型参数明确的场景。
  3. <object, object> : 用于对象和返回值(赋值)泛型参数都无法获取的场景。

以上泛型方法都是从非泛型方法扩展而来。

方法 说明
PathExtensions.PathGet 访问对象的成员值
PathExtensions.PathGetOrDefault 访问对象的成员值, 访问前会检查成员值是否有效,无效时返回default值
PathExtensions.PathSet 对对象的成员赋值
PathHelper.GetDelegate 获取对象成员的取值委托方法
PathHelper.GetDelegateDefault 获取对象成员的可空取值委托方法
PathHelper.GetLambda 获取对象成员的取值Lambda表达式
PathHelper.GetLambdaDefault 获取对象成员的可空取值Lambda表达式
PathHelper.SetDelegate 获取对象成员的赋值委托方法
PathHelper.SetLambda 获取对象成员的赋值Lambda表达式
常见问题 单元测试工具包
文档已更新,请点击 此处 更新。
A new version of this app is available. Click here to update.