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. angular.js - angularJs使用iframe,网页内容自适应的问题2. node.js - 怎么在初始化的时候使得一个子组件不加载?3. angular.js - angularjs移动端项目需要引入外部的PC网页,iframe宽高设定100%,显示的内容依然是PC那种效果,不是缩放成适配屏4. angular.js - 创建项目问题的5. angular.js - ionic命令行执行代码超级卡,要等很久才会有反应6. angular.js - ui-router 有没有手动重新加载路由配置的方法?7. angular.js - 请教angularjs里html和js通信的问题8. 求解决方法:Parse error: syntax error, unexpected9. mysql改密码失败了,旧密码新密码都不能登录了...10. 大神帮忙看一下万分感谢!