加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

vb.net – 选项严格和匿名类型不一起?

发布时间:2020-12-17 00:05:39 所属栏目:大数据 来源:网络整理
导读:我有一个产生匿名类型的 Linq查询.但是,现在我想使用这个匿名类型的参数,它似乎不起作用. For Each obj As Object in QueryDim row As DataRow = obj.parameter...Next obj 现在编译器在表达式obj.parameter上抛出一个错误:“Option Strict On禁止后期绑定
我有一个产生匿名类型的 Linq查询.但是,现在我想使用这个匿名类型的参数,它似乎不起作用.
For Each obj As Object in Query
Dim row As DataRow = obj.parameter
...
Next obj

现在编译器在表达式obj.parameter上抛出一个错误:“Option Strict On禁止后期绑定”.如果我理解正确,编译器不知道匿名类型的参数.我尝试了基于Google搜索结果的Option Infer On(并删除了As Object),但它没有帮助.这似乎有道理,因为它似乎总是向我扩展.

无论如何要解决这个问题,还是应该创建一个自定义类型?

声明匿名类型的代码(即LINQ查询的Select部分)必须与使用它的代码在同一方法中,并且Query变量的声明必须具有推断类型.在将匿名类型转换为Object之后,您无法访问该属性,因为没有可以将其强制转换的命名类型.

因此,请确保您的LINQ查询(或者至少是选择新匿名类型的部分)采用相同的方法.例如.

Dim Query = From prod In products
            Select prod.Name,prod.Price

For Each obj in Query
    Dim name = obj.Name
    ...
Next obj

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读