AngularJS中有关Directive的汇总
本篇通过几个例子对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的汇总的更多相关文章
- angularjs中的directive scope配置
		angularjs中的directive scope配置 定义directive其中重要的一环就是定义scope,scope有三种形式: 默认的scope,DOM元素上原有的scope scope: ... 
- angularjs中的directive
		正在初学angularjs中,在网上看到一篇详细讲解directive指令的文章,于是就记录在这里和大家一起分享 angular.module('docsTransclusionExample', [ ... 
- angularJs中自定义directive的数据交互
		首先放官方文档地址:https://docs.angularjs.org/guide/directive 就我对directive的粗浅理解,它一般用于独立Dom元素的封装,应用场合为控件重用和逻辑模 ... 
- AngularJS中使用Directive、Controller、Service
		AngularJS是一款非常强大的前端MVC框架.同时,它也引入了相当多的概念,这些概念我们可能不是太熟悉. (1)Directive 指令 (2)Controller 控制器 (3)Service ... 
- angularjs中directive指令与component组件有什么区别?
		壹 ❀ 引 我在前面花了两篇博客分别系统化介绍了angularjs中的directive指令与component组件,当然directive也能实现组件这点毋庸置疑.在了解完两者后,即便我们知道co ... 
- angularJS中directive与controller之间的通信
		当我们在angularJS中自定义了directive之后需要和controller进行通讯的时候,是怎么样进行通讯呢? 这里介绍3种angular自定义directive与controller通信的 ... 
- AngularJs中,如何在父元素中调用子元素为自定义Directive中定义的函数?
		最近一段时间准备使用AngularJs中的自定义Directive重构一下代码. 在这里说明一下,把自定义控件封装成Directive并不一定是要复用,而是要让代码结构更加清晰.就好像你将一个长方法拆 ... 
- AngularJS中自定义有关一个表格的Directive
		本篇体验在AngularJS中自定义一个有关表格的Directive.表格的需求包括: ● 表格结构 <table> <thead> <tr> ... 
- angularJS中directive父子组件的数据交互
		angularJS中directive父子组件的数据交互 1. 使用共享 scope 的时候,可以直接从父 scope 中共享属性.使用隔离 scope 的时候,无法从父 scope 中共享属性.在 ... 
随机推荐
- js数值进制互转
			十进制转换为二进制: var num = 100; console.log(num.toString(2)); toString()方法可把一个 Number 对象转换为一个字符串,并返回结果. 语法 ... 
- java  扫描输入
			到目前为止,从文件或标准输入读取数据还是一件相当痛苦第事情,一般第解决之道就是读入一行文本,对其进行分词,然后使用Integer Double 等类第各种解析方法来解析数据: //: strings/ ... 
- 判断上学和放假的demo
			var today = new Date(); var xq = today.getDay(); var Now = today.getHours(); if (xq >= 1 &&am ... 
- Collections.sort   给集合排序
			List<MenuVo> child_menus = new ArrayList<MenuVo>(); for (MenuVo menuVo : child_menus) { ... 
- 开始写博客,学习Linq(3)
			为什么需要Linq?(摘自原文) 读者会发现LINQ着眼于解决编程语言和数据库之间广发存在的不统一问题. 1.常见的问题,使用.NET Framework Class Library(FCL)提供了A ... 
- CentOS6.8安装360 pika
			1.安装依赖包 yum install snappy-devel bz2 libzip-dev libsnappy-dev libprotobuf-dev libevent-dev protobuf- ... 
- C#编程的语法积累(一)
			1.自动属性 之前的实现方式: private int id; public int Id { set {id = value;} get {return id;} } 现在可通过自动属性实现: pu ... 
- openstack安装-计算节点-neutron服务安装
			一.安装nettron相关服务 yum install openstack-neutron-linuxbridge ebtables ipset -y 二.快速配置配置 修改红色部分为计算节点的网卡 ... 
- 063 日志分析(pv  uv  登录人数  游客人数  平均访问时间  二跳率  独立IP)
			1.需求分析 分析指标 pv uv 登录人数 游客人数 平均访问时间 二跳率 独立IP 2.使用的日志(一号店),会话信息 3.创建数据库 4.创建源表,存储源数据 5.创建我们需要的use表 6.创 ... 
- linux下设置php执行命令
			第一种方法: 打开用户根目录下的: vi ~/.bash_profile # .bash_profile # Get the aliases and functions if [ -f ~/.bash ... 
