学习了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. LeetCode:救生艇【881】

    LeetCode:救生艇[881] 题目描述 第 i 个人的体重为 people[i],每艘船可以承载的最大重量为 limit. 每艘船最多可同时载两人,但条件是这些人的重量之和最多为 limit. ...

  2. 一张图学习vim常用命令

    一张图学习vim常用命令

  3. PAT 天梯赛 L3-001. 凑零钱 【DP】【DFS】

    题目链接 https://www.patest.cn/contests/gplt/L3-001 思路 DP[I][J] I 表示第几个物品 J 表示多少钱 dp[i][j] 为 bool 值 表示 当 ...

  4. js 动态加载事件的几种方法总结

    本篇文章主要是对js 动态加载事件的几种方法进行了详细的总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助   有些时候需要动态加载javascript事件的一些方法往往我们需要在 JS 中动态添 ...

  5. 【leetcode刷题笔记】Edit Distance

    Given two words word1 and word2, find the minimum number of steps required to convert word1 to word2 ...

  6. P4240 毒瘤之神的考验

    题目 P4240 毒瘤之神的考验 神仙题\(emmm\) 前置 首先有一个很神奇的性质: \(\varphi(ij)=\dfrac{\varphi(i)\varphi(j)gcd(i,j)}{\var ...

  7. 在ubuntu上为android系统编写Linux驱动程序【转】

    本文转载自:http://blog.csdn.net/luoshengyang/article/details/6568411 在智能手机时代,每个品牌的手机都有自己的个性特点.正是依靠这种与众不同的 ...

  8. [算法]去掉字符串中连续出现的k个0子串

    题目: 给定一个字符串str和一个整数k,如果str中正好有k个‘0’字符出现时,把k个连续的‘0’字符去除,返回处理后的字符串. 举例: str=”A00B”,k=2,返回“AB” str=”A00 ...

  9. 《机器学习实战》学习笔记第十四章 —— 利用SVD简化数据

    相关博客: 吴恩达机器学习笔记(八) —— 降维与主成分分析法(PCA) <机器学习实战>学习笔记第十三章 —— 利用PCA来简化数据 奇异值分解(SVD)原理与在降维中的应用 机器学习( ...

  10. Oracle数据库设计规范建议

    Oracle数据库设计规范建议 1 目的 本规范的主要目的是希望规范数据库设计,尽量提前避免由于数据库设计不当而产生的麻烦:同时好的规范,在执行的时候可以培养出好的习惯,好的习惯是软件质量的很好的保证 ...