angularjs - 我可以制作一个 Angular 指令来匹配 CSS 选择器(不仅仅是标签名称)吗?

标签 angularjs angularjs-directive

我可以定义一个影响所有 <a> 的指令文档中的元素,如下所示:

myApp.directive('a', function() {
  return {
    restrict: 'E',
    link: function(scope, element) {
      // Some custom logic to apply to all <a> elements
    }
  };
});

我可以做同样的事情,但对于匹配给定 CSS 选择器的元素?像这样?
myApp.directive('a[href^="mailto:"]', function() {
  return {
    restrict: 'E',
    link: function(scope, element) {
      // Some custom logic to apply to all <a> elements
      // w/ a href attribute starting in "mailto:"
    }
  };
});

最佳答案

不。

当您在特定名称下注册指令时,angular 会将指令放入新名称下的指令缓存中,或将其推送到指定名称下的现有指令列表中。

之后,angular 搜索 dom 以找到您的指令和 (tagName|attrName|className|commentName) 之间的对应关系,当找到时,angular 调用列表中每个指令的 compile 函数,并将找到的 (element, attrs) 作为参数传递给 compile 函数.

所以在你的情况下 a[href^="mailto:"]将按原样搜索 '<a[href^="mailto:"]></a[href^="mailto:"]>'这显然是不存在的,属性、类和注释也是如此。

在您的情况下,最明智的解决方案是:

myApp.directive('a', function() {
  return {
    restrict: 'E',
    link: function(scope, element, attrs) {
        if (attrs.href.indexOf('mailto:') !== 0) { return; }
        // Some custom logic to apply to all a[href^="mailto:"] elements
    }
  };
});

关于angularjs - 我可以制作一个 Angular 指令来匹配 CSS 选择器(不仅仅是标签名称)吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21146394/

相关文章:

javascript - $viewValue 未应用于文本框指令?

javascript - 如何在规范化/非规范化属性名称之前获取原始属性名称?

angularjs - 如何始终启用 Angular 可编辑的编辑状态

javascript - AngularJS 两个 http get 在一个 Controller 中出现问题

angularjs - 创建包含组件的 Angular 表单的最佳方法是什么?

javascript - 我们应该在哪里存储 JavaScript 调用的服务连接 URL?

AngularJs $http 获取请求 - 如何显示进度条?

javascript - 拒绝 Angular $http promise

angularjs - 将 AngularJS 范围变量从指令传递到 Controller 的最简单方法?

javascript - Angular,使用服务显示数组