使用标签中的冒号访问 JSON 数据

2023-12-10

我的 json 数据在标签中带有冒号(请参阅响应数据),我发现很难使用以下代码在 Angular 中访问它:

<li ng-repeat="i in items.autnresponse.responsedata | searchFor:searchString"> <p>{{i.autn:numhits}}</p> </li>

我不断收到这样的错误:

Error: [$parse:syntax] Syntax Error: Token ':' is an unexpected token at column 7 of the expression [i.autn:numhits] starting at [:numhits].

JSON数据摘录:

"autnresponse": {
    "action": {
        "$": "QUERY"
    },
    "response": {
        "$": "SUCCESS"
    },
    "responsedata": {
        "autn:numhits": {
        "$": "92"
    },
    "autn:totalhits": {
        "$": "92"
    },
    "autn:totaldbdocs": {
        "$": "188"
    },
    "autn:totaldbsecs": {
        "$": "188"
    },

有人知道解决这个问题的方法吗?


我假设我从评论中知道了我的问题的答案,并发布了我的回应:

假设

您的 JSON 解析正常,但您的代码无法访问结果数据结构中的某些内容

Answer

对字符串使用方括号表示法:

var x = i['autn:numhits'];

当变量中有属性名称时,可以使用相同的方法。使用您的相同示例:

var propertyName = 'autn:numhits';
var x = i[propertyName];

Addendum

对于 Angular 模板,请尝试

{{i['autn:numhits']}}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用标签中的冒号访问 JSON 数据 的相关文章

随机推荐