作者:心叶
时间:2018-04-22 10:58

一:自定义指令常用模板

下面是大致的说明,不是全面的,后面来具体说明一些没有提及的细节和重要的相关知识:

angular.module('yelloxingApp', []).directive('uiDirective', function() {return {restrict:String,//标明该指令可以在模板中用于元素E、属性A、类C和注释M或组合priority:Number,//设置指令执行优先级,在某个DOM上优先级高的会先执行terminal:Boolean,template:String or Template Function,//就是设置模板,和下面的templateUrl属性二个只可以设置一个,目的一样templateUrl:String or Template Function,//除了字符串,这二个属性还可以设置函数replace:Boolean,//指令模板是否替换原来的元素scope:Boolean or Object,controller:String or function(scope, element, attrs) { ... },require:String or Array,//你需要知道link在每个实例都执行一遍,compile全程只会执行一遍link: function(scope, element, attrs,ctrl) { ... },compile:function(element, attrs) {//常用的就是compile的此处写执行一次的代码,或者在link方法里面写和dom有关的操作}};
}); 

二:一些属性说明

【scope】

可以设置boolean或者对象,先来说说boolean,这个比较简单:

1.当设置true的时候,表示继承父scope,是一个子scope;

2.当设置false的时候,直接使用父scope。

还有一种对象设置方法,就是设置一种隔离的scope,在使用隔离scope的时候,提供了三种方法同隔离之外的地方交互,下面用一个例子来一一说明:

angular.module('yelloxingApp', []).directive("scopeExample", ['$rootScope', function($rootScope) {return {restrict: 'A',scope: {_userDataName: "=userDataName",_onSend: "&onSend",_fromName: "@fromName"},template: `<button ng-click="_useParentMethod()">点击按钮调用父级的方法</button><input ng-model="_userDataName"/><ul><li>fromName={{newfromname}}</li><li>这是从父级获取到的{{_userDataName}}</li></ul>`,link: function($scope, element, attrs) {//使用@符号可将本地作用域的变量与DOM属性的值进行绑定,即这里通过@得到父类fromName的值$scope.newfromname = $scope._fromName;$scope._useParentMethod = function() {//使用&符号可以在其中调用父类的方法$scope._onSend({ "email": { "email": "yelloxing@gmail.com" } });console.log($scope._userDataName);};}};
}]);

上面是指令的写法,下面来看看控制器里面有什么:

$scope.name = "心叶";$scope.user = "yelloxing";$scope.sendMail = function(email){console.error(email);
}

最后别忘了html里面的使用:

<div scope-example user-data-name="user" on-send='sendMail(email)' from-name={{name}}></div>

【require】

请求另外的controller,然后作为link方法的第四个参数传递进去,我们需要注意的是查找控制器的方法。

查找控制器的方法可以这样理解:使用?表示如果在当前指令中没有找到所需要的控制器,会将null作为传给link函数的第四个参数,如果添加了^前缀,指令会在上游的指令链中查找require参数所指定的控制器,他们也可以组合,比如require: "?^ngModel",如果没有前缀,指令将会在自身所提供的控制器中进行查找,如果没有找到任何控制器(或具有指定名字的指令)就抛出一个错误。

【terminal】

属性terminal:为true时,指示优先级小于当前指令的指令都不执行,仅执行到本指令。

三:视图和model之间的数据格式化

类似过滤器的功能,有时候我们希望页面显示的是数据经过某种翻译后的样子,以便于约定,不过对于数据库也许简单的序号会更有益,因此你可能会需要在link中使用下面的方法来实现这个功能:

1.ctrl.$formatters.unshift(function(input) {//model到view的数据格式化});

2.ctrl.$parsers.unshift(function(input) {//view到model的数据格式化})。

上面的$formatters和$parsers就是二个队列,视图到model和model到视图,会方便经过里面定义的方法的过滤,有点类似管道流,最后流到目的地。

别忘了设置类似require: "?ngModel"这样的语句去查找控制器。

四:视图和model数据同步问题

有时候在指令里面通过jquery修改了input的数据,不过angularjs并不会知道,这时候,你可以选择下面中的一个方法:

1.触发输入框change改变,让Angularjs发现数据改变了,从而去调用$setViewValue(value),同步数据:$("input").trigger("change");

2.直接手动触发同步value到viewValue和modelValue中的行为:ctrl.$setViewValue($scope.info)。

五:几个零碎的技巧

1.根据输入框是否合法来设置true或false:ctrl.$setValidity(errorType, boolean);//errorType表示错误类别,可以自定义

2.设置监听指定的一个model值,当然还有监听集合等方法:$scope.$watch(attrs['ngModel'], function(newValue, oldValue) {});

3.有时候在指令里面新添加的字符串需要被angularjs管理,就可以用下面的方法编译一下:$compile(newHtml)($scope)。

六:常用方法或服务

解析一段字符串(可能是属性也可能是方法)的方法有二个,直接看下面例子:

$scope.getInfo=function(){console.log('这是执行了函数的表现');
};var funName="getInfo()";//执行方法一:
$scope.$eval(funName);
//执行方法二:
$parse(funName)($scope);

关于Angularjs中自定义指令一些有价值的细节和技巧相关推荐

  1. AngularJS中自定义指令

    AngularJS中除了内置指令,还可以自定义指令.自定义指令和自定义过滤器一样,有两种方法: 第一种,在module中配置:$compileProvider.directive('directive ...

  2. AngularJS 的自定义指令

    这是一篇angularjs自定义指令的教程.就让我们来看看,如何在angularjs中自定义指令吧!我们将利用现有的guitar angularjs app,这在 教程14: AngularJ表单验证 ...

  3. AngularJS中的指令全面解析(必看)

    出处: http://www.jb51.net/article/84665.htm 说到AngularJS,我们首先想到的大概也就是双向数据绑定和指令系统了,这两者也是AngularJS中最为吸引人的 ...

  4. 带你走近AngularJS - 创建自定义指令

    带你走近AngularJS系列: 带你走近AngularJS - 基本功能介绍 带你走近AngularJS - 体验指令实例 带你走近AngularJS - 创建自定义指令 ------------- ...

  5. vue点击改变data值_vue 中自定义指令改变data中的值

    通过局部自定义指令实现了一个拖动的指令 html: script: methods:{ set(x,y){ this.data.x=x; this.data.y=y; } }, directives: ...

  6. vue点击改变data_vue 中自定义指令改变data中的值

    通过局部自定义指令实现了一个拖动的指令 html: script: methods:{ set(x,y){ this.data.x=x; this.data.y=y; } }, directives: ...

  7. AngularJS中自定义过滤器

    AngularJS中为我们提供了一些内置的过滤器,这里列举一些自定义过滤器的场景. 自定义过滤器,不带参赛 //过滤 不带参赛 app.filter('ordinal', function () {r ...

  8. vue中自定义指令、组件化、生命周期、节流和防抖、获取DOM、mint-ui简介、过渡和动画

    自定义指令: vue中通过directive方法自定义指令,如:自定义一个v-focus指令: <script>Vue.directive('focus', {//通过directive( ...

  9. vue中自定义指令Vue.directive(指令名, 对象)

    1.自定义全局指令 可以在不同的组件实例中使用, 也就是说在全局任意位置都可以使用Vue.directive(指令名, 对象); // 对象中定义了 该指令的所有生命周期函数方法,也叫钩子函数Vue. ...

最新文章

  1. C#.NET 中的类型转换
  2. 搞了半天,终于弄懂了TCP Socket数据的接收和发送,太难~
  3. Erlang转JAVA,将Erlang UTF-8编码的字符串转换为java.lang.String
  4. 自编码的matlab代码,深度学习自动编码机MATLAB实现
  5. 【Zookeeper】源码分析之服务器(一)
  6. cjmx:JConsole的命令行版本
  7. 用户访问一个网站的全部过程
  8. 第一次作业:深入源码分析进程模型
  9. SQLSERVER中的BCP命令使用
  10. 启动关闭HadoopSpark历史服务
  11. 第三季-第5课-Linux编程规范
  12. oracle脑裂复现,Oracle rac集群环境中的特殊问题
  13. 多线程面试题:词频统计
  14. opencv codebook背景减除
  15. c语言工程中建头文件,在cfree5中建x立多文件项目的方法.doc
  16. 黑苹果oc清除nvram_自己组装一台“iMac”是什么体验(下):AMD 平台也能吃上黑苹果...
  17. MySQL-数据表创建命令
  18. 基于R语言对股市价格预测的ARIMA建模
  19. jSignature.min.js下载地址
  20. 别人都知道的法线贴图流程,你竟然还不知道?真不知道你怎么学的

热门文章

  1. SAP MIGO对工单做101收货,报错 - Check table TFBEFU_CR entry 10 does not exist – 对策
  2. 关于深度残差收缩网络,你需要知道这几点
  3. 不会画饼的领导,不值得托付
  4. 迁移学习,让深度学习不再困难……
  5. “刷脸”之后 声纹识别有望成为新秀
  6. 李彦宏的百度 AI 落地战略,由王海峰来实现
  7. Word2Vec揭秘: 这是深度学习中的一小步,却是NLP中的巨大跨越
  8. Facebook发现:计算机识别系统更青睐识别“有钱人”,准确率高出20%
  9. 深层上下文化的单词表示
  10. 谷歌工程师:聊一聊深度学习的weight initialization