javascript – angularJS $scope.当输入框变空时,$watch无效
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – angularJS $scope.当输入框变空时,$watch无效,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2094字,纯文字阅读大概需要3分钟。
内容图文
![javascript – angularJS $scope.当输入框变空时,$watch无效](/upload/InfoBanner/zyjiaocheng/824/3559533dd0c9444daa0388a754e3c3b8.jpg)
我刚开始使用AngularJS,我正在尝试使用工厂在两个ng控制器(两个控制器都在同一个ng-app模块中)之间共享数据.来自controller1的数据(HTML输入字段)似乎在大多数时间与控制器2共享;但是当我删除输入字段的所有内容时,$watch似乎不起作用!我觉得用语言解释有点困难.下面的屏幕截图可能有所帮助.
这是我的代码:
<!DOCTYPE html>
<html>
<head>
<% include ../partials/head %>
</head>
<body class="container" ng-app='myApp'>
<div ng-controller="ctrl1">
<input type="text" ng-model="firstName">
<br>
Input is : <strong>{{firstName}}</strong>
</div>
<div ng-controller="ctrl2">
Input should also be here: {{firstName}}
</div>
<script>
var myApp = angular.module('myApp', []);
myApp.factory('Data', function () {
var data = {
FirstName: ''
}
return {
getFirstName: function () {
return data.FirstName;
},
setFirstName: function (x) {
data.FirstName = x;
}
}
});
myApp.controller('ctrl1', function ($scope, Data) {
$scope.firstName = ''
$scope.$watch('firstName', function(newVal){
if(newVal){Data.setFirstName(newVal);}
});
});
myApp.controller('ctrl2', function ($scope, Data) {
$scope.$watch(function(){return Data.getFirstName();}, function(newVal){
if(newVal){$scope.firstName = newVal;}
});
});
</script>
</body>
<footer>
<% include ../partials/footer %>
</footer>
</html>
我发现这个代码还有一个jsfiddle. http://jsfiddle.net/5LL3U/2/
任何帮助表示赞赏.谢谢!
解决方法:
你需要同时检查newValue和oldValue.如果是new newValue,它不会调用你的工厂,也不会在变量上设置值. : –
var myApp = angular.module('myApp', []);
myApp.factory('Data', function(){
var data =
{
FirstName: ''
};
return {
getFirstName: function () {
return data.FirstName;
},
setFirstName: function (firstName) {
data.FirstName = firstName;
}
};
});
myApp.controller('FirstCtrl', function( $scope, Data ) {
$scope.firstName = '';
$scope.$watch('firstName', function (newValue,oldValue) {
console.log(oldValue+" "+newValue);
if (newValue!=oldValue) Data.setFirstName(newValue);
});
});
myApp.controller('SecondCtrl', function( $scope, Data ){
$scope.$watch(function () { return Data.getFirstName(); }, function (newValue,oldValue) {
if (newValue!=oldValue) $scope.firstName = newValue;
});
});
小提琴:-http://jsfiddle.net/1d1vL1hd/
内容总结
以上是互联网集市为您收集整理的javascript – angularJS $scope.当输入框变空时,$watch无效全部内容,希望文章能够帮你解决javascript – angularJS $scope.当输入框变空时,$watch无效所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。