angular.js - 请教一个关于angularjs的小问题
问题描述
我是angularjs的一个新手,今天在项目中遇到这样的一个问题我想在1S种以后给p隐藏掉,但是一直没效果,求解,为什么一直没反应
<p ng-show='on'>111</p>app.controller(’myinfoCtrl’, [’$scope’],function($scope) { $scope.on=true; setTimeout(function(){console.log($scope.on)$scope.on=false;console.log($scope.on) },1000)}
问题解答
回答1:
<!DOCTYPE html><html ng-app='app'><head> <title></title> <script type='text/javascript' src='x.js'></script></head><body ng-controller='myinfoCtrl'><p ng-show='on'>111</p><script type='text/javascript'> var app = angular.module(’app’, []); app.controller(’myinfoCtrl’, [’$scope’,function($scope) {$scope.on=true;setTimeout(function(){ console.log($scope.on) $scope.on=false; $scope.$apply(); console.log($scope.on)},1000) }]);</script></body></html>
在回调函数里需要手动调用$scope.$apply();
或者使用$timeouthttp://www.haobala.com/...
望采纳,谢谢
回答2:
用$timeout:
app.controller(’myinfoCtrl’, [’$scope’,’$timeout’],function($scope,$timeout) { $scope.on=true; $timeout(function(){$scope.on=false; },1000)}
直接在setTimeout中改变$scope中绑定的变量不会触发变量的脏数据检查,变量变化不会被同步到界面,因此界面也不会做出更改。
回答3:
我没用过setTimeout, 不过把setTimeout换成$timeout 可以实现你说的效果
回答4:
<p ng-show='on'>111</p>
app.controller(’myinfoCtrl’, [’$scope’],function($scope) {
$scope.on=true;setTimeout(function(){ $scope.$apply(function(){$scope.on=false; });},1000)
}用setTimeout不会触发$digest循环,建议用angular封装好的$timeout吧
回答5:


@流星留步 为什么会报错?
相关文章:
1. javascript - 使用vue2.x时,白屏现象2. Linux下用Vim写Python程序时「查询Python的帮助内容,即Python-doc」能做到如「vim-doc」那样吗?3. java - Win10下 idea的编码设置成了UTF-8,但是返回时乱码显示,哪里有问题??4. javascript - input输入框的失去焦点事件和发送按钮的点击事件冲突5. javascript - 安装vue-cli一直卡在这个状态该怎么解决呢6. html - css 英文段落换行,单词截断7. javascript - 如何判断用户切换到了当前标签页?8. python - (初学者)代码运行不起来,求指导,谢谢!9. javascript - js对象 属性的访问和创建10. javascript - 关于定时器 与 防止连续点击 问题

网公网安备