本篇通过几个例子对AngularJS中的Directive进行汇总。

例子1,单向绑定和双向绑定

<html ng-app="myApp">
<head>
<script src="angualr.js"></script>
<script>
(function(){
var name = "myApp";
requried = [];
myApp = null; myApp = angualr.module(name, requires); myApp.controller("AppCtrl", functioin($scope){
$scope.contacts = [
{firstname: "", lastname: "'},
...
]; $scope.addContact = function(){
$scope.contacts.push({firstname:"", lastname:"", isEnabled:true});
} //切换视图
$scope.viewFile = function(){
if($scope.viewState){
return "contact_list.html";
} else{
return "contact_table.html";
}
} $scope.onPartialLoad = function(){
console.log($scope.viewFile() + " loaded");
}
})
}());
</script>
</head>
<body ng-controller="AppCtrl"> </body>
</html>

==单向绑定

{{contacts.length}}
<div ng-bind="contacts.length"></div>
<div ng-bind-template="">the first name is {{contacts[0].firstname}}</div>
{{contacts[0].firstname}}
{{::contacts.length}} 只展示一次数组长度,当数组长度有改变,这里不变
{{ 2 + 3 }}
{{ Math.min(4, 2)}}
<button ng-click="addContact()">添加</button>
<div ng-non-bindable>this is {{hello }}</div> 这里的{{hello}}会显示出来 ...
<tr ng-repeat="contact in contacts" ng-class="$odd ? 'odd':'even'">
<td>{{$index + 1}}</td>
<td>{{contact.firtname}}</td>
<td>{{contact.lastname}}</td>
<td>{{contact.isEnabled}}</td>
<td>{{$first}}</td>
<td>{{$last}}</td>
<td>{{$middle}}</td>
</tr>
... <ng-include src="'contact_table.html'"></ng-include> //切换视图
<input type="checkbox" ng-model="viewState">切换视图
<ng-include src="viewFile()" onload="onPartialLoad()"></ng-include>

==使用Directive的几种方式

<div ng-bind="contacts.length"></div>
<div class="ng-bind:contacts.length"></div>
<ng-include></ng-include>

==双向绑定

<input type="text" ng-model="contacts[0].firstname"/>

例子2,ng-switch

<html ng-app="myApp">
<head>
angular.js
<script>
(function(){
var name = "myApp[]",
requires = [],
myApp = null; myApp = angular.module(name, requires);
myApp.controller("AppCtrl", function($scope){
$scope.data = {};
});
}());
</script>
</head>
<body ng-controller="AppCtrl">
</body>
</html>

页面部分

<div ng-repeat="channel in ['None', 'Tv', 'kitty']"  ng-cloak>
<input type="radio" name ="leisure" value="{{channel}}" ng-model="data.whichChannel" ng-checked="$first" />{{channel}}
</div> <div ng-switch on="data.whichChannel">
<div ng-switch-default>this is none</div>
<div ng-switch-when="Tv">this is tv</div>
<div ng-switch-when="kitty">this is kitty</div>
</div>

以上,

● ng-checked 勾选
● ng-switch切换显示其中的内容
● 当点击Tv相关的这个RadioButton,把Tv这个值赋值给了data对象的whichChannel字段,whichChannel字段值得改变会告诉ng-swich所在的div,其子元素的ng-switch-when值如果和当前的whichChannel字段值匹配,就显示
● ng-cloak 避免绑定数据的时候页面闪烁

例子3,显示、隐藏、移除元素,ng-show, ng-hide, ng-if

$scope.toggleNewContact = false;
$scope.shwoNewContactForm = function(){
$scope.toggleNewContact = true;
} <button ng-click="showNewContactForm()">Add New Contact</button>
<form ng-show="toggleNewContact">
<button ng-click="toggleNewContact = false">Cancel</button>
</form> <tr ng-repeat="contact in contacts" ng-if="contact.isEnabled">
</tr>

例子4,勾选,只读,禁用,链接

$scope.checkMe = true;
$scope.url = "http://google.com";
$scope.imgSrc = "hi.jpeg"; //勾选
<input type="checkbox" ng-checked="{{checkME}}" /> check me //禁用按钮
<button ng-disabled="{{checkMe}}">Click me</button> //只读
<input type="text" value="he" ng-readonly="{{checkMe}}" /> //链接
<a href="{{url}}">go</a>
<a ng-href="{{url}}">go</a> 推荐使用 //图片
<img ng-src="{{imgSrc}}"/>

例子5,ng-style

<button ng-click="styles={'color':'red'}">set color</button>
<button ng-click="styles={'font-weight':'bold'}">bold</button>
<button ng-click="styles={'font-style':'italic'}>italic></button>
<p ng-style="styles">hello</p>

例子6,ng-class

.strike{
    text-decoration:line-through;
}

.bold{
    font-weight:bold;
}

.red{
    color:red;
}

==把一个值赋值给ng-class

//文本框和controller中的style变量绑定起来
<input type="text" ng-model="style" />
<p ng-class="style">he</p>

==把一个对象赋值给ng-class

<input type="checkbox" ng-model="deleted" /> deleted
<input tyep="checkbox" ng-model="important" /> important
<input type="checkbox" ng-model="error"> error
<p ng-class="{strike:deleted, bold:important, red:error}">hello</p>

==把一个数组赋值给ng-class

//运用所有的class
<p ng-class="['strike','bold','red']">hi</p>

另外,

<tr ng-repeat="contact in contacts" ng-class-odd="'odd'" ng-class-even="'even'"></tr>

例子7, 事件

ng-click, ng-mousedown, ng-mouseenter, ng-mouseleave, ng-mouseup

例子8,过滤

==对数组元素过滤

$scope.courses = [
{name:"", category:"", timeline:20, price:25},
...
]; $scope.getTargetDate = function(days){
var now = new Date();
return now.setDate(now.getDate() + days);
} <tr ng-repeat="course in courses">
<td>{{$index + 1}}</td>
<td>{{course.name | upplercase}}</td>
<td>{{course.category | lowercase }}</td>
<td>{{getTargetDate(course.timeline) | date: 'dd MMM yy' | uppercase }}</td>
<td>{{course.price | currency: "¥" }}</td>
<td>{{course | json}}</td>
</tr>

==对整个数组过滤

$scope.limitVal = 10;
$scope.lessThan25 = function(item){
return item.price <;
} {{courses.length}}
<button ng-click="limitVal = 5">5</button>
<button ng-click="limitVl = 10">10</button>
//<input type="text" ng-model="searchStr" />
//<input type="text" ng-model="name" />
//<input type="text" ng-model="category"/> //<tr ng-repeat = "course in courses | limitTo: limitVal | filter: searchStr">
//<tr ng-repeat = "course in courses | limitTo: limitVal | filter: {name: name, category:category}">
//<tr ng-repeat = "course in courses | limitTo: limitVal | filter: lessThan25">
//<tr ng-repeat = "course in courses | limitTo: limitVal | orderBy: '-price'">
<tr ng-repeat = "course in courses | limitTo: limitVal | orderBy: ['name','-price']">
<td>{{$index + 1}}</td>
<td>{{course.name}}</td>
<td>{{course.category}}</td>
<td>{{course.timeline}}</td>
<td>{{course.price}}</td>
</tr>

所以filter能接受的包括字符串、对象和函数。

AngularJS中有关Directive的汇总的更多相关文章

  1. angularjs中的directive scope配置

    angularjs中的directive scope配置 定义directive其中重要的一环就是定义scope,scope有三种形式: 默认的scope,DOM元素上原有的scope scope: ...

  2. angularjs中的directive

    正在初学angularjs中,在网上看到一篇详细讲解directive指令的文章,于是就记录在这里和大家一起分享 angular.module('docsTransclusionExample', [ ...

  3. angularJs中自定义directive的数据交互

    首先放官方文档地址:https://docs.angularjs.org/guide/directive 就我对directive的粗浅理解,它一般用于独立Dom元素的封装,应用场合为控件重用和逻辑模 ...

  4. AngularJS中使用Directive、Controller、Service

    AngularJS是一款非常强大的前端MVC框架.同时,它也引入了相当多的概念,这些概念我们可能不是太熟悉. (1)Directive 指令 (2)Controller 控制器 (3)Service ...

  5. angularjs中directive指令与component组件有什么区别?

     壹 ❀ 引 我在前面花了两篇博客分别系统化介绍了angularjs中的directive指令与component组件,当然directive也能实现组件这点毋庸置疑.在了解完两者后,即便我们知道co ...

  6. angularJS中directive与controller之间的通信

    当我们在angularJS中自定义了directive之后需要和controller进行通讯的时候,是怎么样进行通讯呢? 这里介绍3种angular自定义directive与controller通信的 ...

  7. AngularJs中,如何在父元素中调用子元素为自定义Directive中定义的函数?

    最近一段时间准备使用AngularJs中的自定义Directive重构一下代码. 在这里说明一下,把自定义控件封装成Directive并不一定是要复用,而是要让代码结构更加清晰.就好像你将一个长方法拆 ...

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

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

  9. angularJS中directive父子组件的数据交互

    angularJS中directive父子组件的数据交互 1. 使用共享 scope 的时候,可以直接从父 scope 中共享属性.使用隔离 scope 的时候,无法从父 scope 中共享属性.在 ...

随机推荐

  1. 转:10分钟了解JS堆、栈以及事件循环的概念

    https://juejin.im/post/5b1deac06fb9a01e643e2a95?utm_medium=fe&utm_source=weixinqun 前言 其实一开始对栈.堆的 ...

  2. 追求极致--纯css制作三角、圆形按钮,兼容ie6

    参考了天猫.微博等网站的做法,用纯html和css实现,效果还是不错的.以下是成果,兼容主流浏览器,包括ie6. <!DOCTYPE html PUBLIC "-//W3C//DTD ...

  3. laravel console - 自定义命令

    在改造一个支付流程,新的流程加入了一个新的数据表字段,但是这个新的字段需要通过计算来填充,所以为了兼容历史数据,必须将已有的数据行重新计算一遍该字段. 这时使用 laravel console 命令就 ...

  4. 检查Rabbitmq中队列及消息个数,还有清空的方法

    rabbitmqctl list_queues rabbitmqctl purge_queue kafka_queue (不推荐)使用reset方式重置rabbitmq即清空掉rabbitmq所有的队 ...

  5. Hibernate的核心对象关系映射

    Hibernate的核心就是对象关系映射: 加载映射文件的两种方式: 第一种:<mapping resource="com/bie/lesson02/crud/po/employee. ...

  6. jQuery源码中的“new jQuery.fn.init()”什么意思?

    所有文章搬运自我的个人主页:sheilasun.me 引子 最近打算试试看看jQuery的源码,刚开个头就卡住了.无论如何都理解不了jQuery源码入口部分中的 return new jQuery.f ...

  7. HDU 2955_Robberies 小偷抢银行【01背包】

    <题目链接> 题意: 先是给出几组数据,每组数据第一行是总被抓概率p(最后求得的总概率必须小于他,否则被抓),然后是想抢的银行数n.然后n行,每行分别是该银行能抢的钱数m[i]和被抓的概率 ...

  8. c# 深入探索之CLR

    概念: CLR : 公共语言运行时(Common Language Runtime) 是一个可由多种编程语言使用的"运行时",它负责资源管理(内存分配和垃圾收集等),并保证应用和底 ...

  9. Windows10下 tensorflow-gpu 配置

    引言 越来越多的的人入坑机器学习,深度学习,tensorflow 作为目前十分流行又强大的一个框架,自然会有越来越多的新人(我也刚入门)准备使用,一般装的都是 CPU 版的 tensorflow,然而 ...

  10. vimtutor学习笔记

    简介 vimtutor是vim这款知名的文本编辑器的学习工具/指南.语法如下. vimtutor [-g] [language] gvimtutor -g选项和gvimtutor是启动GUI版本的指南 ...