首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何从控制器函数中获取$scope?

如何从控制器函数中获取$scope?
EN

Stack Overflow用户
提问于 2016-02-15 09:45:50
回答 1查看 271关注 0票数 0

我有以下问题:控制器内有一个函数,该函数决定$scope.name的值

代码语言:javascript
运行
复制
app.controller('myController', ['$scope', function($scope) {
    function myFunction() {
       $scope.name = 'myName';
    }
document.getElementById('my-id').addEventListener("click", myFunction);
}])

由于多种原因,我不能使用ng-单击。更新:由于光擦拭图库和社会分享我不能使用ng-单击。我想要添加自定义FB共享,如果我使用ng-单击它将关闭照片擦拭打开的图像。请参阅 这里示例。打开图像并单击左上角自定义共享按钮

注意,即使我在这里使用这个示例,它也不会将我的$scope.name绑定到html。

如果我试着记录它的价值,它就会成为一种魅力。

代码语言:javascript
运行
复制
console.log($scope.name); //will work perfectly

在html中,它将不绑定值:

代码语言:javascript
运行
复制
<div ng-controller="myController">
<button id="my-id">
   <p>{{name}}</p>
</button>
</div>
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-02-15 09:52:33

对于专题解决方案,问题是普通的事件侦听器将绕过摘要周期。这意味着您的$scope正在更新,但是Angular不知道它,因为触发更新的事件不在radar的雷达上,因此角不更新模板。解决此问题的(bad)解决方案是使用$scope.$apply强制触发摘要。

但是,ng-click,这是一个非角度的解决方案,如果你解决了的任何问题,你会更好。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35406007

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档