- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想使用 Javascript 的 array.filter 从数组中删除项目,因为语法优雅且可读。但是,过滤器似乎没有修改原始数组,它只是返回一个新数组,按照您的要求进行过滤。我的问题是,为什么下面的操作不像我预期的那样工作?
$scope.clearList = function () {
this.list = this.list.filter(function (item) {
return item.checked == true;
});
//...
}
我希望在返回新过滤的数组后,this.list 现在将只包含过滤后的集合。然而,它不是这样工作的。 this.list 最终包含完全相同的项目。更改代码以在中间变量中保存过滤后的数组表明它确实在正确过滤。
我现在已经做了一个变通方法,循环遍历过滤后的版本,并将应过滤的原始列表中的项目拼接出来,但这是不雅的。我是不是想错了?
旁注:我正在使用 Angular.js。我不确定它是否重要,但列表来自以下内容:
<div class="list" ng-repeat="list in lists">
<!-- ... -->
<ul>
<li ng-repeat="item in list">
<div>
<label>
<input type="checkbox" ng-model="item.checked"/>
{{item.name}}
</label>
<!-- ... -->
</div>
</li>
</ul>
<button class="btn clear-selected" ng-click="clearList()">
Remove Selected
</button>
</div>
编辑以添加调试信息:我引入了一个临时变量只是为了查看调试器中发生了什么。
var temp = this.list.filter(function (item) {
return item.checked == true;
});
this.list = temp;
执行前,this.List有5项,temp未定义。第一行执行后,this.List有5项,temp有2项。最后一行执行完后,this.List有2项,temp有2项。
但是,此后绑定(bind)到 this.list 的 UI 似乎没有更新。所以似乎确实发生了与过滤器无关的事情。
最佳答案
在 Angular 中,您使用特殊的 $scope
变量修改数据,而在您的 Controller 中,this
指向 $scope
作为执行context,$scope
是首选。
当 UI 不更新时,通常是因为“模型”(或给定范围的属性)的更改是在 Angular 之外完成的。在这种情况下,需要调用 $apply
。这会通知 Angular 某些内容已更改并更新 View 。
但是,这似乎不是您的问题。我这里有一个工作 list ,改动很小 http://plnkr.co/edit/Cnj0fEHSmi2L8BjNRAf5?p=preview
这是 Controller 的内容,当您从 UI 调用 clearList()
时,列表中只会留下选中的项目。
$scope.list = [
{name: 'one', checked: true},
{name: 'two', checked: false},
{name: 'three', checked: true},
{name: 'four', checked: false}
];
$scope.clearList = function () {
$scope.list = $scope.list.filter(function(item) {
return item.checked === true;
});
};
现在,我建议将列表传递给 clearList clearList(list)
或者更好地使用 Angular 过滤器。
关于javascript - 使用 Javascript Array.Filter 修改原始数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13885866/
我应该在 Angular 应用程序中使用哪个,为什么? array.filter(o => o.name === myName); 或 $filter('filter')(array, {name:
以下两个调用是否解析为 Django 中的等效 SQL 查询? 链接多个调用 Model.objects \ .filter(arg1=foo) \ .filter(arg2=bar) \ ... 将
我正在尝试在 hbase-1.0.0 上运行 completebulkload。但是遇到错误, "java.lang.NoClassDefFoundError: org/apache/hadoop/h
我从这篇文章中学习了“树”和“索引”:Learning Git Internals by Example 但是当谈到“git filter-branch”命令时,我不知道“--tree-filter”
我正在尝试构建我的自定义过滤器以进行身份验证,但是当我尝试运行我的 WebAPI 解决方案时遇到了这个问题: The given filter instance must implement on
我想保留一个过滤器函数的列表,并通过返回true的过滤器来标记这些项。这是接近但不完全。。主要问题是std::stringify!总是返回“ADF”,可能是我声明为ADF的变量名。。第二个问题是,在定
我想保留一个筛选器函数列表,并通过返回True的筛选器来标记这些项目。这已经很接近了,但还不完全是。。主要问题是std::stringify!总是返回“ADF”,可能是我声明为ADF的变量名。。第二个
我尝试在 graphql 查询中使用 where: filter 但不幸的是我遇到了一些错误。我做错了什么? shoeposts { data { attributes(where: {s
几周以来,我一直在使用 Zend Framework 2,尽管在线文档非常不完整,但我还是设法建立了我的网站的初稿。 不幸的是,我在尝试实现 Zend\Filter\File\Rename 过滤器的自
我正在尝试在 APC 中使用 apc.filter 等功能。但是我所做的一切都不起作用 我应该完成 2 项任务。 1)需要包含1个目录用于缓存。我的代码在apc.ini apc.cache by de
我想使用一个可能返回 Err 的过滤器函数结果,并将其冒泡到包含函数: mycoll.into_iter() .filter(|el| { if el == "bad" { E
每个 Controller 都应该有方法filters(),在那里你可以指定一些类,我想知道,这些类是如何被框架包含的?这些类是如何配置的,以及何时配置,也许有人可以给我一个使用filters()并包
我想在一维信号上使用巴特沃斯滤波器。在 Matlab 中,脚本如下所示: f=100; f_cutoff = 20; fnorm =f_cutoff/(f/2); [b,a] = butter
我想比较两个列表,以便找到第一个列表中不在第二个列表中的值并返回它们。提前谢谢大家代码返回:不再支持过滤器有没有其他方法可以做到这一点 MATCH (cu:Customer{name: "myCust
在 Android 应用程序中,我有一个通用设置 -- 一个带有 ArrayAdapter 的 ListView。在某一时刻,我调用了适配器的 getFilter().filter() 方法,它很好地
所以我有如下数据: [ { "id": 0, "title": "happy dayys", "owner": {"id": "1", "username
阅读Mastering Web Development with AngularJS ,我正在尝试创建并使用一个使用 $filter 模块/关键字的新过滤器。 HTML
所以我的理解是 halt 命令应该停止当前过滤器中的请求,但它似乎继续。下面是一个非常简单的 Sinatra 应用程序,演示了这一点。 服务器.rb require 'sinatra' before
我正在尝试将散列传递给 URL 以设置 UIkit 过滤器。 All
我正在使用 django-filter应用程序。但是有一个问题我不知道如何解决。它几乎与 django 文档中描述的完全相同: https://docs.djangoproject.com/en/1.
我是一名优秀的程序员,十分优秀!