gpt4 book ai didi

javascript - 使用搜索输入字段过滤 ng-repeat 中的嵌套对象

转载 作者:数据小太阳 更新时间:2023-10-29 06:14:54 27 4
gpt4 key购买 nike

我正在尝试使用搜索文本框过滤 ng-repeat 中的嵌套对象。

给定以下对象:

$scope.items = {
"1": {
name: "First Item",
tag: "first"
},
"2": {
name: "Second Item",
tag: "second"
}
};

我想做这样的事情:

<input type="text" name="serchBox" ng-model="searchByName">
<p ng-repeat="(key, values) in items | filter:{name: searchByName}">
Using both {{key}} and {{values.name}}
</p>

这确实不行。我尝试了很多东西,但无法使其正常工作。 我不想改变我的对象。我搜索了很多,但没有找到适合我需要的东西。

最佳答案

我终于找到了我自己问题的答案。

我只需要创建自己的过滤器并使用正则表达式检查对象内的属性是否具有所需的值:

app.filter('customSearchFilter', function() {
return function(input, term) {
var regex = new RegExp(term || '', 'i');
var obj = {};
angular.forEach(input, function(v, i){
if(regex.test(v.name + '')){
obj[i]=v;
}
});
return obj;
};
});

并以这种方式在 HTML 中应用它:

<input type="text" ng-model="searchName" />
<ul>
<li ng-repeat="(key, val) in items | customSearchFilter:searchName">Both {{key}} and {{val.name}}</li>
</ul>

我创建了这个 Plunker展示我的实际解决方案

关于javascript - 使用搜索输入字段过滤 ng-repeat 中的嵌套对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41743724/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com