首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >angularjs:两次调用的指令链接函数

angularjs:两次调用的指令链接函数
EN

Stack Overflow用户
提问于 2017-06-25 18:53:47
回答 1查看 692关注 0票数 0

我正在创建我的第一个指令,我遇到了一些奇怪的行为。我的链接函数中的 console.log()被调用了两次。我在谷歌上搜索了一些解决方案,但是我不知道如何修改代码来改变行为.

我的index.html:

代码语言:javascript
复制
<html>
<head>
  <title>GCSE Directive TEST</title>
</head>
<body ng-app="gcseTest">

  <google-image-search query="Test query"></google-image-search>

  <!-- Scripts -->
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.8/angular.js"></script>
  <script src="gcse-directive.js"></script>
</body>
</html>

gcse-指令:

代码语言:javascript
复制
angular.module('gcseTest', [])
  .directive('googleImageSearch', [ function(){
      return {
        scope: {
          query: '@'
        },
        templateUrl: 'gcse-popup.html',
        restrict: 'E',
        replace: true,
        link: function ($scope, $element, $attrs) {
          $scope.search = function(){
            console.log("Gebruik query in link-functie: " + $scope.query);
            return "Gebruik query via popup: " + $scope.query;
          }
        }
      };
  }]);

gcse-popup.html:

代码语言:javascript
复制
<div>
  <h1>Directive Test</h1>
  {{search(query)}}
</div>

有人能解释一下这是怎么回事吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-06-25 19:25:02

您的指令链接函数不会被调用两次,它的search函数将被调用两次。它背后的原因是被调用了两倍,您已经直接使用了search函数,就像在视图绑定中一样,所以每当摘要周期运行时,您的视图绑定都会得到评估。在本例中,摘要周期被运行了两次,这就是为什么您的search函数运行了两次,并且您可以看到console打印了两次。

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

https://stackoverflow.com/questions/44749513

复制
相关文章

相似问题

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