学习了angularJS一周,但是大部分时间被自定义指令占用了。博主表示自学互联网好心塞的,发现问题的视觉很狭窄,这比解决问题要更难。这篇文章首先介绍了自定义,然后介绍了在使用自定义指令遇到的问题。

代码模板:

var myModule = angular.module("myModule",[]);

myModule.directive('directiveName',function(){  

 return{ restrict:string,     

template:string,    

 templateUrl:string, replace:boolean,     

transclude:boolean,     

scope:bollean 或 object,     

link:function(scope,element,attrs){  },

compile:function(element,attrs,transclude){  } ...  

 }

.directive('指令名', [参数1,参数2,… function(形参1’, 形参2’,…) {}])//该参数是固定的。

第一个参数是指令的名字。定义指令的名字,应该使用驼峰命名法,使用时用-连接。

第二个参数使用一个数组,这是为了防止压缩代码后转义。数组的最后一个元素是一个函数。

restrict:指定如何在模板中使用自定义指令,可取E、A、C、M中的一个或任意组合。默认值为A。

E:表示元素的名称;A:表示元素的属性;C:表示CSS中的class;M:表示注释。

元素和标签使用:

div ng-controller="InController">
<!-- inputdirct作为属性使用 -->
<div add-one="name" add-two="name" inputdirct class="div1"> </div>
</br></br>
<!-- inputdirct作为标签使用 -->
<inputdirct add-one="name" add-two="name"></inputdirct>
</div>

template:指令的内联模板;

template:指令的内联模板的url;

replace:若取值伪true,模板(template)替换指令所在的元素;若取为false,把模板(template)放在指令所在元素的内部。默认值为false。

transclude:把指令元素的子元素移到指令内联模板的内部。

scope : false:自定义指令的scope对象就是指令所在的scope对象(作用域) true:自定义指令建立了一个scope对象,并继承了外层的scope。

object:自定义指令创建了一个scope对象,不继承外层的scope,该scope与外层scope隔离。

自定义指令scope通信:通过传递属性名映射的方式把父scope中指定的属性传递给这个独立的scope。

绑定方式如下:

(1)@:单向文本绑定,传递一个字符串值。当父作用域属性改变时,隔离的scope中的属性值随着变化;当隔离的scope中的属性值改变时,父作用域的属性值不随着变化。

(2)= :双向绑定,传递父作用域的属性,传递的数据类型可以是字符串、数组、对象等。当父作用域属性改变时,隔离的scope中的属性值会发生变化;当隔离的scope中的属性发生变化时,父作用域的属性也会发生变化。

(3)&:执行父作用预计中的函数。

分析:@和=区别

<div ng-controller="InController">
<inputdirct add-one="name" add-two="name"></inputdirct>
</div>
<script src="bower_components/angular/angular.js"></script>
<script>
var app = angular.module("App",[]);
// 控制器
app.controller('InController',['$scope',function($scope){
// $scope.inputdate = '';
$scope.name='LiShuyi';//控制器中给name赋值‘Lishuyi’,添加到属性add-one和add-two中 $scope.$watchCollection('name',function(now,old){console.log(now)}); }]);
// 自定义指令
app.directive("inputdirct",function(){
return{
restrict : 'EA',
scope:{addOne:'@',
addTwo:'='},
template:'<span>使用@单向文本绑定{{addOne}}</span></br>\
<span>使用=双向文本绑定{{addTwo}}</span>',
// 分别使用@和=引用add-one和add-two,通过浏览器的输出结果可以发现,@输出的di元素中add-one属性的值,而=输出的是在控制器中赋值的name。
} });

compile、link:这两个选项关系到AngularJS的生命周期。

angularJS中自定义指令的更多相关文章

  1. AngularJS中的指令全面解析(转载)

    说到AngularJS,我们首先想到的大概也就是双向数据绑定和指令系统了,这两者也是AngularJS中最为吸引人的地方.双向数据绑定呢,感觉没什么好说的,那么今天我们就来简单的讨论下AngularJ ...

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

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

  3. AngularJS中自定义有关一个表格的Directive

    本篇体验在AngularJS中自定义一个有关表格的Directive.表格的需求包括: ● 表格结构 <table>    <thead>        <tr>  ...

  4. vue中自定义指令

    //vue中自定义指令 //使用 Vue.directive(id, [definition]) 定义全局的指令 //参数1:指令的名称.注意,在定义的时候,指令的名称前面,不需要加 v-前缀; 但是 ...

  5. 走进AngularJs(四)自定义指令----(中)

    上一篇简单介绍了自定义一个指令的几个简单参数,restrict.template.templateUrl.replace.transclude,这几个理解起来相对容易很多,因为它们只涉及到了表现,而没 ...

  6. AngularJS笔记--自定义指令

    在前端开发中, 我们会遇到很多地方都会用到同一种类型的控件.AngularJS提供了自定义指令功能,我们可以在指令里面定义特定的html模板.提供给前台html调用. 一. 指令的简单定义.  下面定 ...

  7. 走进AngularJs(五)自定义指令----(下)

    自定义指令学习有段时间了,学了些纸上谈兵的东西,还没有真正的写个指令出来呢...所以,随着学习的接近尾声,本篇除了介绍剩余的几个参数外,还将动手结合使用各参数,写个真正能用的指令出来玩玩. 我们在自定 ...

  8. 走进AngularJs(三)自定义指令-----(上)

    一.有感而发的一些话 在学习ng之前有听前辈说过,angular上手比较难,初学者可能不太适应其语法以及思想.随着对ng探索的一步步深入,也确实感觉到了这一点,尤其是框架内部的某些执行机制,其复杂程度 ...

  9. AngularJS中的指令

    欢迎大家讨论与指导 : )  前言 当AngularJS中的内置指令不能满足我们的需求,或者当我们需要创建一个能够用于多个AngularJS程序的自包含的功能单元时,我们应该创建自定义指令来满足需求. ...

随机推荐

  1. mysql存储引擎(待补充)

    数据库中的表也应该有不同的类型,表的类型不同,会对应mysql不同的存取机制,表类型又称为存储引擎 存储引擎说白了就是如何存取数据.如何为存储的数据建立索引和如何更新.查询数据等技术的实现方法.因为在 ...

  2. LeetCode:完全平方数【279】【DP】

    LeetCode:完全平方数[279][DP] 题目描述 给定正整数 n,找到若干个完全平方数(比如 1, 4, 9, 16, ...)使得它们的和等于 n.你需要让组成和的完全平方数的个数最少. 示 ...

  3. LeetCode:汇总区间【228】

    LeetCode:汇总区间[228] 题目描述 给定一个无重复元素的有序整数数组,返回数组区间范围的汇总. 示例 1: 输入: [0,1,2,4,5,7] 输出: ["0->2&quo ...

  4. ubuntu下单网卡绑定多个IP

    第一种方式静态修改. 进入 /etc/network/ 目录下.修改interfaces文件. # The primary network interfaceauto eth0iface eth0 i ...

  5. 326 集合 ,数据类型的补充 ,copy , 编码之间的转换

    一.数据类型补充1,对于元组:如果只有一个元素,并且没有逗号,此元素是什么数据类型,改表达式就是什么数据类型. tu = () tu1 = (,) print(tu,type(tu)) #1 < ...

  6. China sets economic reform priorities for 2015

    BEIJING -- China's State Council, the cabinet, on Monday unveiled this year's priorities for economi ...

  7. 剑指offer之 数组中出现次数超过一半的数字

    public class Solution { public int MoreThanHalfNum_Solution(int [] array) { if(array==null||array.le ...

  8. Docker学习(三)

    查看docker daemon服务运行状态 service docker status

  9. jsp的9个内置对象

    Jsp提供了request.response.session.application.out.page.config.exception.pageContext9个内置对象. 1. Request R ...

  10. 计算地球上两个坐标点(经度,纬度)之间距离sql函数

    go --计算地球上两个坐标点(经度,纬度)之间距离sql函数 --作者:lordbaby --整理:www.aspbc.com CREATE FUNCTION [dbo].[fnGetDistanc ...