指令(Directive)

AngularJS 有一套完整的、可扩展的、用来帮助 Web 应用开发的指令集

在 DOM 编译期间,和 HTML 关联着的指令会被检测到,并且被执行

在 AngularJS 中将前缀为 ng- 这种属性称之为指令,其作用就是为 DOM 元素调用方法、定义行为绑定数据等

简单说:当一个 Angular 应用启动,Angular 就会遍历 DOM 树来解析 HTML,根据指令不同,完成不同操作

注意:HTML5 允许扩展的(自制的)属性,以 data- 开头。

AngularJS 属性以 ng- 开头,但是您可以使用 data-ng- 来让网页对 HTML5 有效。

二者效果相同。

1、ng-app 指令

ng-app指令用来标明一个AngularJS应用程序

标记在一个AngularJS的作用范围的根对象上

系统执行时会自动的执行根对象范围内的其他指令

可以在同一个页面创建多个ng-app节点

但是angular找到第一个ng-app过后就不会再找

 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>ng-app 指令</title>
</head> <body ng-app="myApp">
<!-- angular找到第一个ng-app过后就不会再找 -->
<div ng-controller="App1Controller">
<input type="button" value="按钮1" ng-click="do1()">
</div>
<div ng-controller="App2Controller">
<input type="button" value="按钮2" ng-click="do2()">
</div>
<script src="bower_components/angular/angular.js"></script>
<script>
// 零件1
var myApp1 = angular.module('myApp1', []);
myApp1.controller('App1Controller', ['$scope', function($scope) {
$scope.do1 = function() {
console.log(11111);
};
}]);
// 零件2
var myApp2 = angular.module('myApp2', []);
myApp2.controller('App2Controller', ['$scope', function($scope) {
$scope.do2 = function() {
console.log(22222);
};
}]); angular.module('myApp', ['myApp1', 'myApp2']);
</script>
</body> </html>

2、ng-bind指令

ng-bind指令在绑定的值包含HTML时会转义,为了安全(跨站脚本攻击)

 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>ng-bind-html 指令</title>
</head> <body ng-app="myApp" ng-init="username='<h1>shit</h1>'">
<!-- <strong>{{username}}</strong> -->
<!-- ng-bind指令在绑定的值包含HTML时会转义,为了安全(跨站脚本攻击) -->
<strong ng-bind-html="username"></strong>
<script src="bower_components/angular/angular.js"></script>
<script src="bower_components/angular-sanitize/angular-sanitize.js"></script>
<script>
// 使用自定义的模块才可以依赖别的包里面定义模块,angular定义的默认模块没有依赖任何
angular.module('myApp', ['ngSanitize']);
</script>
</body> </html>

3、ng-repeat指令

ng-repeat指令用来编译一个数组重复创建当前元素,如

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>ng-repeat 指令</title>
</head> <body ng-app="myApp"> <ul ng-controller="ListController">
<!-- ng-repeat 会遍历数组中每一个元素,分别创建li -->
<li ng-repeat="item in ledamei track by $index" data-id="{{item.id}}">
<span>{{$first?'开始':''}}</span>
<strong>{{item.name}}</strong>
&nbsp;&nbsp;&nbsp;&nbsp;
<span>{{item.age}}</span>
<span>{{$last?'没有了':''}}</span>
</li>
</ul> <script src="bower_components/angular/angular.js"></script>
<script>
angular.module('myApp', [])
.controller('ListController', ['$scope', function($scope) { $scope.ledamei = []; for (var i = 1; i < 10; i++) {
$scope.ledamei[$scope.ledamei.length] = {
id: i,
name: '乐乐' + i,
age: 20 + i
};
} }]);
</script>
</body> </html>

4、ng-class 指令

ng-class指令可以设置一个键值对,用于决定是否添加一个特定的类名,键为class名,值为bool类型表示是否添加该类名

 <ul class="messages">

     <li ng-repeat="item in messages track by $index" ng-class="{red:item.read}">

         {{item.content}}

     </li>

 </ul>
 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>ng-repeat 指令</title>
<style>
.red {
color: red;
} .green {
color: green;
}
</style>
</head> <body ng-app="myApp">
<input type="text" ng-model="lastname">
<ul ng-controller="ListController">
<li ng-repeat="name in students track by $id($index)" ng-class="{red:lastname!=''&&name.startsWith(lastname)}">{{name}}</li>
</ul>
<script src="bower_components/angular/angular.js"></script>
<script>
angular.module('myApp', [])
.controller('ListController', ['$scope', function($scope) { $scope.students = ['邓乐', '赵四', '王明', '张晓', '李三', '李三']; }]);
</script>
</body> </html>

5、ng-show/ng-hide 指令

ng-show/ng-hide指令会根据属性值去确定是否展示当前元素,例如ng-show=false则不会展示该元素

 <ul class="messages">

     <li ng-repeat="item in messages track by $index" ng-show="item.read">

         {{item.content}}

     </li>

 </ul>

6、ng-if是指是否存在DOM元素

7、ng-link/ng-src 指令

ng-link/ng-src指令用于解决当链接类型的数据绑定时造成的加载BUG,如

 <!-- 浏览器在解析HTML时会去请求{{item.url}}文件 -->

 <img src="{{item.url}}">

 <!-- 可以使用ng-src解决该问题 -->

 <img ng-src="{{item.url}}">
 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>ng-src</title>
<script src="bower_components/angular/angular.js"></script>
</head> <body ng-app ng-init="imgUrl='22.png'" ng-cloak>
<img ng-src="{{imgUrl}}" alt=""> <a ng-href="{{imgUrl}}">跳转到图片</a>
</body> </html>

8、ng-switch

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>ng-switch 指令</title>
</head>
<body ng-app>
<select ng-model="selected">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
<div ng-switch="selected">
<div ng-switch-when="1">
你选择的是1
</div>
<div ng-switch-when="2">
你选择的是2
</div>
<div ng-switch-when="3">
你选择的是3
</div>
<div ng-switch-default>
你什么都没选
</div>
</div> <script src="bower_components/angular/angular.js"></script>
</body>
</html>

9、ng-checked

ng-checkedng-selected 只会做数据到视图的同步,不会做视图到数据的同步

 <!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<title>ng-xxx 其他指令</title>
</head> <body ng-app>
<p>
<input type="checkbox" ng-model="checked">全选/取消全选</p>
<ul>
<!-- ng-checked 和 ng-selected 只会做数据到视图的同步,不会做视图到数据的同步 -->
<li>选项01
<input type="checkbox" ng-checked="checked">
</li>
<li>选项02
<input type="checkbox" ng-checked="checked">
</li>
<li>选项03
<input type="checkbox" ng-checked="checked">
</li>
<li>选项04
<input type="checkbox" ng-checked="checked">
</li>
<li>选项05
<input type="checkbox" ng-checked="checked">
</li>
</ul>
<script src="bower_components/angular/angular.js"></script>
</body> </html>

10、其他常用指令

ng-model

ng-class

ng-show/ng-hide/ng-if

ng-click

ng-link/ng-src

11、自定义指令

AngularJS中可以通过代码自定义指令:

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

     return {

         restrict: 'E',

         template: '<h1>Hello world</h1>',

         replace: true

     };

 });

 myApp.directive("ngHover", function() {

     return function(scope, element, attrs) {

         element.bind("mouseenter", function() {

             element.css("background", "yellow");

         });

         element.bind("mouseleave", function() {

             element.css("background", "none");

         });

     }

 });

第215天:Angular---指令的更多相关文章

  1. angular指令深度学习篇

    angular指令深度学习-过滤器 limitTo ... <body ng-app="app" > <div ng-controller="myCtr ...

  2. Angular指令渗透式理解

    通过一段时间对angular指令的使用,理解了angular指令的意义,下面逐一介绍一下. ng-app:定义一个angualr模块,表示angular作用的范围,如下代码: ng-app在html标 ...

  3. Angular4 后台管理系统搭建(9) - 用自定义angular指令,实现在服务端验证

    最近这段时间发现,北京这用angular4 或 angular2的公司很少.几乎是没有.很担心自己是不是把精力放到了不应该的地方.白耽误了时间.但是随着我对新版angular框架理解的加深.个人感觉a ...

  4. angular指令之complie和link不得不说的故事

    angular指令比较晦涩难懂的就是complie和link字段了,什么时候该用complie?什么时候该用link?总是很难分别清楚.当理解了指令的真正编译原理的时候,就会发现这相当的简单. ng怎 ...

  5. 【转】angular指令入坑

    独立作用域和函数参数 通过使用本地作用域属性,你可以传递一个外部的函数参数(如定义在控制器$scope中的函数)到指令.这些使用&就可以完成.下面是一个例子,定义一个叫做add的本地作用域属性 ...

  6. angular 指令作用域 scope

    转载自:https://segmentfault.com/a/1190000002773689 下面我们就来详细分析一下指令的作用域. 在这之前希望你对AngularJS的Directive有一定的了 ...

  7. Angular指令1

    Angular的指令 也就是directive,其实就是一WebComponent,以前端的眼光来看,好象很复杂,但是以后端的眼光来看,还是非常简单的.其实就是一个中等水平的类. var myModu ...

  8. angular指令大全

    这篇文章的案例都是来自官方,引用的cdn来自bootcss, 因为angular的官方网站被屏了, 所以要翻, 不过我把整个文档下回来了,方便大家下载可以点击: 打开下载英文版 angular的指令 ...

  9. 初学angular-简单的angular指令

    实现一个简单的input清空内容,且清空对应ngModel 前台部分 <html ng-app="hpapp"> <head> <meta chars ...

  10. 学习angular 指令构造器时遇到的小问题

    在学习angular时,使用模块来为应用添加自己的指令时,遇到了一个问题,演示的代码如下: <!DOCTYPE html> <html> <head> <me ...

随机推荐

  1. 快速搭建属于自己的mongodb数据库

    前言 MongoDB 是一个基于分布式文件存储的数据库.由C++语言编写,支持Windows,Linux,OSX,Solaris等平台,默认端口为27017,是一个效率非常高的nosql数据库. 我的 ...

  2. 利用自定义 ORM 下使用 flask-login 做登录校验使用笔记

    1. 安装: pip install flask_login 2. 使用: 注册应用 import os from flask_login import LoginManager, current_u ...

  3. navicat连接mysql出现1251错误

    刚刚安装热乎的navicat发现出现1251错误,原因不大清楚,找到一个解决办法: 将mysql的密码重新重置一遍: 1.打开命令行 ,进入mysql所在的目录,输入 mysql -uroot -p ...

  4. oracle数据库之rownum和rowid用法

    Rownum 和 Rowid是Oracle数据库所特有的,通过他们可以查询到指定行数范围内的数据记录.   以下通过例子讲解: -- 为了方便,首先,查找dept表中的所有. select deptn ...

  5. 005 -- Mysql数据库引擎特点分析

    常用的数据库引擎的特点: ISAM: ISAM是一个定义明确且历经时间考验的数据表格管理方法,它在设计之时就考虑到数据库查询次数要远大于更新次数.因此,ISAM执行读取操作的速度很快,而且不占用大量的 ...

  6. 企业上云这四大要点,你 get 了吗?

    本文由 Platform9(一家专注于云计算.专有云.混合云.OpenStack 以及容器技术的北美初创公司)技术产品营销经理 Akshai Parthasarathy 撰写,描述了企业在向云基础设施 ...

  7. 02_python内置模块_timeit

    timeit模块可以用来测试一小段python代码的执行速度. (1)timeit.Timer(stmt='pass', setup='pass', timer=<timer function& ...

  8. Codeforces1101 | EducationalRound58 | 瞎讲报告

    目录 Educational Codeforces Round 58 (Rated for Div. 2) A. Minimum Integer B. Accordion C. Division an ...

  9. 2、Ansible在使用过程中出现的错误解决方法

    1.安装完成后允许命令出错 Traceback (most recent call last): File "/usr/bin/ansible", line 197, in (ru ...

  10. 原生JavaScript实现的贪吃蛇

    github代码地址:https://github.com/McRayFE/snake 涉及到的知识点: 键盘事件 setInterval()定时器 javascript中数组的使用 碰撞的检测 of ...