angularjs directive scope变化为啥html,学习AngularJs:Directive指令用法(完整版)

本教程使用AngularJs版本:1.5.3

摘要:Directive(指令)笔者认为是AngularJ非常强大而有有用的功能之一。它就相当于为我们写了公共的自定义DOM元素或CLASS属性或ATTR属性,并且它不只是单单如此,你还可以在它的基础上来操作scope、绑定事件、更改样式等。通过这个Directive,我们可以封装很多公共指令,比如分页指令、自动补全指令等等。然后在HTML页面里只需要简单的写一行代码就可以实现很多强大的功能。一般情况下,需要用Directive有下面的情景:

1. 使你的Html更具语义化,不需要深入研究代码和逻辑即可知道页面的大致逻辑。

2. 抽象一个自定义组件,在其他地方进行重用。

一、Directive的定义及其使用方法AngularJs的指令定义大致如下

angular.module("app",[]).directive("directiveName",function(){

return{

//通过设置项来定义

};

})

Directive可以放置于元素名、属性、class、注释中。下面是引用myDir这个directive的等价方式。(但很多directive都限制为“属性”的使用方式)

directive-name="exp">//属性

directive-name: exp;">//class

<directive-name>directive-name>//元素

//注释

如下一个实例 :

AngularJS入门学习

var app = angular.module('myApp', []);

app.directive('helloWorld', function() {

return {

restrict: 'E',

template: '

Hi 我是林炳文~~~
',

replace: true

};

});

结果:

d0c03735b1a4c7676700cf1b18e53ca8.png

下面是一个directive的详细版

var myModule = angular.module(...);

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

var directiveDefinitionObject = {

priority: 0,

template: '

templateUrl: 'directive.html',

replace: false,

transclude: false,

restrict: 'A',

scope: false,

compile: function compile(tElement, tAttrs, transclude) {

return {

pre: function preLink(scope, iElement, iAttrs, controller) { ... },

post: function postLink(scope, iElement, iAttrs, controller) { ... }

}

},

link: function postLink(scope, iElement, iAttrs) { ... }

};

return directiveDefinitionObject;

});

二、Directive指令内容解读可 以看到它有8个内容

1.restrict

(字符串)可选参数,指明指令在DOM里面以什么形式被声明;取值有:E(元素),A(属性),C(类),M(注释),其中默认值为A;当然也可以两个一起用,比如EA.表示即可以是元素也可以是属性。

[html] view plain copy 在CODE上查看代码片派生到我的代码片

E(元素):

A(属性):

C(类):

M(注释):

一般情况下E/A/C用得比较多。

2.priority(数字),可选参数,指明指令的优先级,若在单个DOM上有多个指令,则优先级高的先执行;

3.terminal(布尔型),可选参数,可以被设置为true或false,若设置为true,则优先级低于此指令的其他指令则无效,不会被调用(优先级相同的还是会执行)

4.template(字符串或者函数)可选参数,可以是:(1)一段HTML文本

AngularJS入门学习

var app = angular.module('myApp', []);

app.directive('helloWorld', function() {

return {

restrict: 'E',

template: '

Hi 我是林炳文~~~

',

replace: true

};

});

7be711a61c5fba0cb4f83803acb7a916.png

(2)一个函数,可接受两个参数tElement和tAttrs

其中tElement是指使用此指令的元素,而tAttrs则实例的属性,它是一个由元素上所有的属性组成的集合(对象)形如:

其中title就是tattrs上的属性

下面让我们看看template是一个函数时候的情况

AngularJS入门学习

var app = angular.module('myApp', []);

app.directive('helloWorld', function() {

return {

restrict: 'E',

template: '

Hi 我是林炳文~~~

',

replace: true

};

});

app.directive("helloWorld2",function(){

return{

restrict:'EAC',

template: function(tElement,tAttrs){

var _html = '';

_html += '

' +'hello '+tAttrs.title+'
';

return _html;

}

};

});

结果:

7978ad96ba4e572d3696f680d1401674.png

可以看到指令中还用到了hello-world2中的标签中的 title字段

5.templateUrl(字符串或者函数),可选参数,可以是(1)一个代表HTML文件路径的字符串

(2)一个函数,可接受两个参数tElement和tAttrs(大致同上)

注意:在本地开发时候,需要运行一个服务器,不然使用templateUrl会报错 Cross Origin Request Script(CORS)错误。由于加载html模板是通过异步加载的,若加载大量的模板会拖慢网站的速度,这里有个技巧,就是先缓存模板

你可以再你的index页面加载好的,将下列代码作为你页面的一部分包含在里面。

Hi 我是林炳文~~~

这里的id属性就是被设置在templateUrl上用的。

AngularJS入门学习

var app = angular.module('myApp', []);

app.directive('helloWorld', function() {

return {

restrict: 'E',

templateUrl: 'hello.html',

replace: true

};

});

Hi 我是林炳文~~~

输出结果:

ae8336bab345926e758e2dbed0a106d4.png

另一种办法缓存是:

app.run(["$templateCache", function($templateCache) {

$templateCache.put("hello.html",

"

Hi 我是林炳文~~~

");

}]);

使用实例如下:

AngularJS入门学习

var app = angular.module('myApp', []);

app.directive('helloWorld', function() {

return {

restrict: 'E',

templateUrl: 'hello.html',

replace: true

};

});

app.run(["$templateCache", function($templateCache) {

$templateCache.put("hello.html",

"

Hi 我是林炳文~~~

");

}]);

结果:

b3e071ea792c27838a737f4c1557ef53.png

其实第一种方法还好一些,写起来会比较快,笔者就得最多的也是第一种写法,直接包在scprit当中

6.replace

(布尔值),默认值为false,设置为true时候,我们再来看看下面的例子(对比下在template时候举的例子)

82cbe3c51daf462ca4d975d1294bf001.png

replace为true时,hello-world这个标签不在了,反之,则存在。

7.scope

(1)默认值false。表示继承父作用域;

(2)true。表示继承父作用域,并创建自己的作用域(子作用域);

(3){}。表示创建一个全新的隔离作用域;

7.1首先我们先来了解下scope的继承机制。我们用ng-controller这个指令举例,

AngularJS入门学习

父亲:{{name}}

var app = angular.module('myApp', []);

app.controller('MainController', function ($scope) {

$scope.name = '林炳文';

});

app.directive('myDirective', function () {

return {

restrict: 'EA',

scope:false,

template: '

儿子:{{ name }}
'

};

});

接下来我们通过一个简单明了的例子来说明scope取值不同的差别:

scope:false

b5904aa35549bb295905a07d4de93531.gif

scope:true

bf3ce236f974467fb34b14a583eb1b84.gif

scope:{}

cba73f6c8c1e49460a8a5e5a9312f2c2.gif

当为false时候,儿子继承父亲的值,改变父亲的值,儿子的值也随之变化,反之亦如此。(继承不隔离)

当为true时候,儿子继承父亲的值,改变父亲的值,儿子的值随之变化,但是改变儿子的值,父亲的值不变。(继承隔离)

当为{}时候,没有继承父亲的值,所以儿子的值为空,改变任何一方的值均不能影响另一方的值。(不继承隔离)

tip:当你想要创建一个可重用的组件时隔离作用域是一个很好的选择,通过隔离作用域我们确保指令是‘独立'的,并可以轻松地插入到任何HTML app中,并且这种做法防止了父作用域被污染;

7.2隔离作用域可以通过绑定策略来访问父作用域的属性。

directive 在使用隔离 scope 的时候,提供了三种方法同隔离之外的地方交互。这三种分别是

@ 绑定一个局部 scope 属性到当前 dom 节点的属性值。结果总是一个字符串,因为 dom 属性是字符串。

& 提供一种方式执行一个表达式在父 scope 的上下文中。如果没有指定 attr 名称,则属性名称为相同的本地名称。

= 通过 directive 的 attr 属性的值在局部 scope 的属性和父 scope 属性名之间建立双向绑定。

@ 局部 scope 属性

@ 方式局部属性用来访问 directive 外部环境定义的字符串值,主要是通过 directive 所在的标签属性绑定外部字符串值。这种绑定是单向的,即父 scope 的绑定变化,directive 中的 scope 的属性会同步变化,而隔离 scope 中的绑定变化,父 scope 是不知道的。

如下示例:directive 声明未隔离 scope 类型,并且使用@绑定 name 属性,在 directive 中使用 name 属性绑定父 scope 中的属性。当改变父 scope 中属性的值的时候,directive 会同步更新值,当改变 directive 的 scope 的属性值时,父 scope 无法同步更新值。

js 代码:

AngularJS入门学习
父scope:
Say:{{name}}
改变父scope的name:
隔离scope:
隔离scope(不使用父scope {{name}}):

var app = angular.module('myApp', []);

app.controller("myController", function ($scope) {

$scope.name = "hello world";

}).directive("isolatedDirective", function () {

return {

scope: {

name: "@"

},

template: 'Say:{{name}}
改变隔离scope的name:'

};

});

结果:页面初始效果

3e1dca49c66d06378e3f9a65788f50db.png

动画效果:

e250580cd4942db974b63f0beba0457f.gif

可以看到父scope上的内容发生改变,子scope同时发生改变。而子scope上的内容发生改变。不影响父scope上的内容!

= 局部 scope 属性

= 通过 directive 的 attr 属性的值在局部 scope 的属性和父 scope 属性名之间建立双向绑定。

意思是,当你想要一个双向绑定的属性的时候,你可以使用=来引入外部属性。无论是改变父 scope 还是隔离 scope 里的属性,父 scope 和隔离 scope 都会同时更新属性值,因为它们是双向绑定的关系。

示例代码:

AngularJS入门学习
父scope:
Say:{{user.name}}
改变父scope的name:
隔离scope:

var app = angular.module('myApp', []);

app.controller("myController", function ($scope) {

$scope.userBase = {

name: 'hello',

id: 1

};

}).directive("isolatedDirective", function () {

return {

scope: {

user: "="

},

template: 'Say:{{user.name}}
改变隔离scope的name:'

}

})

效果:

8b7d4c2c8d874e23471cf5be73bb533d.gif

可以看到父scope和子scope上的内容一直都是一样的!

& 局部 scope 属性

& 方式提供一种途经是 directive 能在父 scope 的上下文中执行一个表达式。此表达式可以是一个 function。

比如当你写了一个 directive,当用户点击按钮时,directive 想要通知 controller,controller 无法知道 directive 中发生了什么,也许你可以通过使用 angular 中的 event 广播来做到,但是必须要在 controller 中增加一个事件监听方法。

最好的方法就是让 directive 可以通过一个父 scope 中的 function,当 directive 中有什么动作需要更新到父 scope 中的时候,可以在父 scope 上下文中执行一段代码或者一个函数。

如下示例在 directive 中执行父 scope 的 function。

AngularJS入门学习
父scope:
Say:{{value}}
隔离scope:

var app = angular.module('myApp', []);

app.controller("myController", function ($scope) {

$scope.value = "hello world";

$scope.click = function () {

$scope.value = Math.random();

};

}).directive("isolatedDirective", function () {

return {

scope: {

action: "&"

},

template: ''

}

})

效果:

0966f8a9c62f257b47417f7731006dab.gif

指令的内容比较多,下面再来讲讲transclude、compline、link、contrller

8.transclude

如果不想让指令内部的内容被模板替换,可以设置这个值为true。一般情况下需要和ngTransclude指令一起使用。 比如:template:"

hello every
",这时,指令内部的内容会嵌入到ng-transclude这个div中。也就是变成了
hello every
这是指令内部的内容
。默认值为false;这个配置选项可以让我们提取包含在指令那个元素里面的内容,再将它放置在指令模板的特定位置。当你开启transclude后,你就可以使用ng-transclude来指明了应该在什么地方放置transcluded内容AngularJS入门学习
  • First link
  • Second link

var app = angular.module('myApp', []);

app.directive('sidebox', function() {

return {

restrict: 'EA',

scope: {

title: '@'

},

transclude: true,

template: '

'

};

});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/571326.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

通信、计算机、电子相关专业技术工作

中国联合网络通信有限公司&#xff08;福建分公司2018招聘&#xff09;<1>IT工程师相应岗位&#xff08;软件方向&#xff09;岗位需求1.以C/C等计算机语言为主要武器&#xff0c;参与公司IT开发、维护、优化2.根据公司发展和业务需求进行软件设计、参与代码开发、系统测…

python可视化报表制作教程_如何使用Python快速制作可视化报表

数据可视化能力已经越来越成为各岗位的基础技能。领英的数据报告显示&#xff0c;数据可视化技能在2017年中国最热门技能中排名第一。就数据分析而言&#xff0c;可视化探索几乎是你正式进行数据分析的第一步&#xff0c;通过SQL拿到数据之后&#xff0c;我们需要使用可视化方法…

vfp程序改错 计算机和英语,vfp程序改错教案.doc

Visual Foxpro程序改错〖第1题〗(练习题所在文件夹:163)*题目&#xff1a;该程序完成口令检验功能。输入三次不正确退出。*注意&#xff1a;不可以增加或删除程序行&#xff0c;也不可以更改程序的结构。SET TALK OFFCLEARass1"AbCdEf"TT1DO WHILE TT<410,20 SAY …

青春

青春 最后一班午夜列车&#xff0c;悄悄地带走了青春&#xff0c;溪水淌过的路终将不会倒流而去。 青春就像一件新买的衬衫&#xff0c;尽管新颖夺目&#xff0c;却始终逃不了岁月的洗礼&#xff0c;一遍一遍的脱去新颖的靓丽&#xff0c;尽管你小心的呵护&#xff0c;终将守护…

lisp遍历表中所有顶点_三十张图片让你彻底弄明白图的两种遍历方式:DFS和BFS...

1 引言遍历是指从某个节点出发&#xff0c;按照一定的的搜索路线&#xff0c;依次访问对数据结构中的全部节点&#xff0c;且每个节点仅访问一次。  在二叉树基础中&#xff0c;介绍了对于树的遍历。树的遍历是指从根节点出发&#xff0c;按照一定的访问规则&#xff0c;依次…

未来教育计算机二级预测c,二级C语言(附光盘)(全国计算机等级考试预测试卷与真考题库)...

摘要&#xff1a;高质量预测试卷 首创命题模拟系统,专家层层把关,瞄准每年的更新试题 最新版无纸化考试题库 提供1035道题,所有试题均有正确答案与详尽解析 无纸化真考模拟系统 操作环境,评分机制与真实考试系统的完全一致,带您提前"进入"考场 名师视频课堂 机考误区…

通用测试用例大全

为方便平时写测试用例&#xff0c;整理如下&#xff1a; 功能条件测试步骤测试数据预期结果备注搜索或查询 单独遍历各查询条件&#xff0c;测试按各查询条件是否都能够查询出相应的值. 查询出符合条件的记录 设置界面上所有查询条件进行查询,单击查询按钮后&#xff0c;测试执…

cαr怎么发音_【英语拼读发音规则】连读、略读、重读、断句、语调……

在说汉语的时候&#xff0c;我们讲究的是“字正腔圆、掷地有声”&#xff0c;而英语恰恰相反&#xff0c;它需要将一句话中的某些重点词汇突出&#xff0c;弱化非重点词汇。所以&#xff0c;对已经习惯了“字正腔圆”的我们来讲&#xff0c;就会觉得英语听起来“太含含糊糊”了…

中职计算机英语c答案,中职高考计算机试题及答案-20210622105004.docx-原创力文档...

* 1&#xff0e;计算机采用“存储程序”原理的提出者是()A&#xff0e;莫尔B&#xff0e;比尔盖茨C&#xff0e;冯 诺依曼D&#xff0e;科得2&#xff0e;下列表示计算机运行速度的是()A. 7200转B. 2GHZC&#xff0e; 20GD. 1024 x 768像素(l00101 ) 2 对应的十进制数是( )A. 3…

WEB网站测试思路

1、链接测试&#xff1a;a:进入页面后点击链接是否正常跳转 b:单独将链接复制到浏览器里面是否正常展示页面&#xff08;如果需要登录的网站&#xff0c;还需要考虑个人中心等需要登录的功能在未登录成功时以及登录成功后直接通过链接打开的情况&#xff09; 2、菜单测试&#…

计算机病毒属于什么类工具,什么是计算机病毒?有哪些类型

病毒定义一、计算机病毒(Computer Virus)在《中华人民共和国计算机信息系统安全保护条例》中被明确定义&#xff0c;病毒指“编制或者在计算机程序中插入的破坏计算机功能或者破坏数据&#xff0c;影响计算机使用并且能够自我复制的一组计算机指令或者程序代码”。而在一般教科…

织梦缩略图自动补齐绝对路径_[教程]织梦CMS缩略图和文章内容图片自动转化为带域名的绝对路径...

今天又接了个织梦CMS的有偿服务,客户想要后台添加文章内容的时候,缩略图自动变成带上绝对路径的格式.比如我们默认的缩略图是这样的 /uploads/allimg/150814/123P2NB-0-lp.png 他想要的效果是这样的 http://fcz8k.com/uploads/allimg/150814/123P2NB-0-lp.png大家懂我意思了吧…

Net学习日记_ASP.Net_MVC_新语法笔记

01.新语法 本章中主要讲解.Net框架性语法。开发者可以使用新语法提高编程的效率以及代码的运行效率&#xff1b;其本质都是“语法糖”&#xff0c;由编译器在编译时转成原始语法。 1 自动属性 Auto-Implemented Properties 2 隐式类型 var 3 对象初始化器 与 集合初始化器 { …

燕山大学数字通信计算机仿真代码,燕山大学数字通信计算机仿真课程设计模板.doc...

??数字通信计算机课设??程序代码?//?SigTranmit.cpp:?implementation?of?the?SigTranmit?class.?//?//??#include?"stdafx.h"?#include?"ASK.h"?#include?"SigTranmit.h"?#include???#ifdef?_DEBUG?#undef?THIS_FILE…

inventor如何钣金出弧面_Inventor教程之钣金多规则

钣金多规则是继钣金多实体之后&#xff0c;Inventor 在钣金模块功能的又一重要增强。钣金多规则基于钣金多实体的基础上&#xff0c;完善了用户需要在不同实体上赋予不同板厚、展开规则、折弯释压形状、拐角释压形状以及尺寸等针对各实体的个性化设置。使用户可以把钣金多规则和…

Mybatis_接口编程

Mybatis参考使用文档&#xff1a;http://www.mybatis.org/mybatis-3/zh/index.html 1.项目结构 2.新增EmployeeMapper.java接口代码 package com.atguigu.mybatis.dao;import com.atguigu.mybatis.bean.Employee;public interface EmployeeMapper {public Employee getEmpById(…

计算机楼综合布线设计图,宿舍楼综合布线设计含图.doc

宿舍楼综合布线设计含图信息工程学院-网络规划与综合布线PAGE第 PAGE 10 页 共10页目 录HYPERLINK \l _Toc5475 摘要1HYPERLINK \l _Toc2717 关键词 1HYPERLINK \l _Toc30683 前言11.综合布线设计原则布 HYPERLINK \l _Toc20365 1HYPERLINK \l _Toc1695 2. 总体结构1HYPERLINK …

iconv 判断字符编码_GBK 和 UTF8编码

相关学习内容&#xff1a;https://study.163.com/course/courseMain.htm?courseId1210747815&share2&shareId480000002227524​study.163.com9节课征服「字符编码」 - 网易云课堂9节课征服「字符编码」 - 网易云课堂​study.163.com首先来看一下常用的编码有哪些&…

完美粉红噪声及各种声波测试软件,粉红噪声的测试原理

粉红噪声。既然是噪声就绝对不是单纯的纯音&#xff0c;它是一种频率覆盖范围很宽的声音。低频能下降到接近0Hz(不包括0Hz)高频端能上到二十几千赫&#xff0c;而且它在等比例带宽内的能量是相等的(误差只不过0.1dB左右)。比如用1/3oct带通滤波器去计算分析&#xff0c;我们会发…

oracle 11g jdbc jar包在哪个文件目录

一. 如果装了oracle数据库的话, 大致是这样的目录&#xff1a; D:\oracle\product\11.2.0\client_1\oui\jlib\classes12.jar 或者 D:\oracle\product\11.2.0\dbhome_1\oui\jlib\classes12.jar 注意&#xff1a; 对于oracle11的jdbc\lib下没有classer12.jar文件&#xff0…