3

我刚开始在我的开发应用程序中使用 Angular 1.2.0,我注意到以下功能不再起作用,看看:

var myItems = angular.model('myItems', []);

myItems.controller('itemsController', function($scope, $http) {

    // delete item from the database
    $scope.deleteItem = function(id) {
        $http.delete('/api/items/' + id)
            .success(function(data) {
                $scope.items = data;
            })
            .error(function(data) {
                // log error 
            });
    };
});

然后在我看来,这就是触发删除项目的原因:

<input type="checkbox" data-ng-click="deleteItem(item._id)"> {{ item.text }}

我对 Angular 很陌生,所以我不确定这里到底出了什么问题,并且查看 Angular 存储库上 1.2 版的变更日志文件并没有得到答案。有更多 Angular 经验的人可以向我解释这里到底是什么问题吗?

编辑:这是来自 Chrome 错误控制台的日志,页面加载后即可看到。单击复选框以删除项目不会执行任何操作。

Error: [$parse:isecprv] http://errors.angularjs.org/undefined/$parse/isecprv?p0=deleteItem(item._id)
at Error (<anonymous>)
at https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:6:453
at ha (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:84:103)
at https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:87:372
at Array.forEach (native)
at q (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:7:261)
at rc (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:87:354)
at Jb.readIdent (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:149:31)
at Jb.lex (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:144:199)
at Ya.parse (https://ajax.googleapis.com/ajax/libs/angularjs/1.2.0/angular.min.js:151:12) <input type="checkbox" data-ng-click="deleteItem(item._id)">

更新:事实证明,Angular 1.2.0-rc2(当前最新的稳定版本)中的一项重大变化是在作用域链上引入了私有属性。这可能会破坏许多将数据存储在面向文档的数据库中的应用程序,例如在我的案例MongoDB中。如果您遇到同样的问题,您可以暂时返回到版本1.2.0-rc3 (此处为Google CDN ),或者按照更改日志中的建议将敏感 API 包装在闭包/控制器中。

4

2 回答 2

1

在错误控制台中,第一个链接指向页面

http://docs.angularjs.org/error/$parse:isecprv?p0=deleteItem(item._id)

此页面说明错误是您在表达式中使用了私有属性。

表达式是deleteItem(item._id)

_id- 是项目的私有财产。

于 2013-11-13T06:52:03.623 回答
0

尝试更改字段名称( _id )。从错误控制台可以清楚地看到此错误。

从 Angular 版本1.2

不允许在 Angular 表达式中引用私有字段!表达式:deleteItem(item._id)

名称以下划线开头或结尾的字段被视为私有字段。Angular 表达式不允许引用作用域链上的此类字段。

更多信息

于 2013-11-13T06:47:28.110 回答