我一定错过了一些非常基本的东西。我有一个输入框,在其中输入了列表名称。然后将该名称保存到Firebase。
使用时$watch
,效果很好。但是,如果通过ng-keyup
事件完成,则返回以下错误
TypeError:未定义不是函数。
我想念什么?
HTML:
<input id="which_list" ng-keyup="enterThis($event)" ng-model="which_list.name" >{{which_list.name}}</span>
控制器:
$scope.which_list = sync.$asObject();
$scope.$watch('which_list.name', function() {
gDataService.which_list.name= $scope.which_list.name;
$scope.which_list.$save() // THIS WORKS
// $scope.which_list => d {$$conf: Object, $id: "id", $priority: null, name: "to1_list", $save: function…}
.then(function(){
console.log($scope.which_list.name);
});
});
$scope.enterThis = function(event){
if (event.keyCode === 13) {
gDataService.which_list.name= $scope.which_list.name;
$scope.which_list.$save(); // THIS DOESN't WORK
// $scope.which_list = Object {name:"list_name"}
}
};
编辑:在注释中,我包括了$scope.which_list
在断点处显示的值。
当前,当您正在将范围which_list
转换为普通的旧JavaScript对象(POJO)时,我相信您无法在范围变量和之间进行三向绑定$asObject()
。
代码
var which_list = sync.$asObject();
// set up 3-way data-binding
which_list.$bindTo($scope, "which_list");
更新
另外,由于您正在使用$scope.which_list
包含名称和其他属性的对象,因此请在启动控制器时将其初始化,例如
$scope.which_list = {}
希望这可以帮助您,谢谢。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句