- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的指令设置如下:
angular.module("app", []).directive("myDirective", function(){
return {
scope: {},
link: function($scope){
$scope.myFunction = function(){
//Do DOM manipulation
}
}
}
});
在我的 html 中我只是有
<div my-directive>
<a href="" ng-click="myFunction()">Click Me</a>
</div>
当我单击“Click Me”时,控制台不会打印任何内容,但是,如果我删除范围属性或将其更改为 scope:true
那么它会按预期工作。我知道这与隔离范围有关,但我不完全理解发生了什么。我想要一个隔离范围,因为这将是一个模块化指令,我将在许多不同的项目中使用。
注意:我使用的是 Angular 1.4.6
更新:该函数需要进行 DOM 操作。这就是为什么它位于链接函数中。
最佳答案
这不起作用的原因是 link
的使用方式。
由于元素在指令存在之前就已存在于指令中,因此这些元素不会使用 link
中的信息进行编译。要获得您想要的内容,您需要将这些元素放入 template
或 templateUrl
中,以便可以针对 link
进行编译。
这是一个例子:
angular.module("myApp", []).directive("myDirective", function() {
return {
scope: {},
template: '<a href="" ng-click="myFunction()">Click Me {{value}}</a>',
link: function(scope) {
scope.value = 'Value here';
scope.myFunction = function() {
console.log('you are here.');
}
}
}
});
<script data-require="angular.js@1.4.6" data-semver="1.4.6" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.6/angular.min.js"></script>
<div ng-app="myApp">
<div my-directive>
<a href="" ng-click="myFunction()">Click Me {{value}}</a>
</div>
</div>
关于javascript - 在指令链接函数中访问作用域上的函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32915551/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!