本篇通过几个例子对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. js数值进制互转

    十进制转换为二进制: var num = 100; console.log(num.toString(2)); toString()方法可把一个 Number 对象转换为一个字符串,并返回结果. 语法 ...

  2. java 扫描输入

    到目前为止,从文件或标准输入读取数据还是一件相当痛苦第事情,一般第解决之道就是读入一行文本,对其进行分词,然后使用Integer Double 等类第各种解析方法来解析数据: //: strings/ ...

  3. 判断上学和放假的demo

    var today = new Date(); var xq = today.getDay(); var Now = today.getHours(); if (xq >= 1 &&am ...

  4. Collections.sort 给集合排序

    List<MenuVo> child_menus = new ArrayList<MenuVo>(); for (MenuVo menuVo : child_menus) { ...

  5. 开始写博客,学习Linq(3)

    为什么需要Linq?(摘自原文) 读者会发现LINQ着眼于解决编程语言和数据库之间广发存在的不统一问题. 1.常见的问题,使用.NET Framework Class Library(FCL)提供了A ...

  6. CentOS6.8安装360 pika

    1.安装依赖包 yum install snappy-devel bz2 libzip-dev libsnappy-dev libprotobuf-dev libevent-dev protobuf- ...

  7. C#编程的语法积累(一)

    1.自动属性 之前的实现方式: private int id; public int Id { set {id = value;} get {return id;} } 现在可通过自动属性实现: pu ...

  8. openstack安装-计算节点-neutron服务安装

    一.安装nettron相关服务 yum install openstack-neutron-linuxbridge ebtables ipset -y 二.快速配置配置  修改红色部分为计算节点的网卡 ...

  9. 063 日志分析(pv  uv  登录人数  游客人数  平均访问时间  二跳率  独立IP)

    1.需求分析 分析指标 pv uv 登录人数 游客人数 平均访问时间 二跳率 独立IP 2.使用的日志(一号店),会话信息 3.创建数据库 4.创建源表,存储源数据 5.创建我们需要的use表 6.创 ...

  10. linux下设置php执行命令

    第一种方法: 打开用户根目录下的: vi ~/.bash_profile # .bash_profile # Get the aliases and functions if [ -f ~/.bash ...