AngularJS優(yōu)雅的自定義指令
學(xué)習(xí)要點
•為什么使用指令
•創(chuàng)建自定義指令
•使用jqLite工作
一、為什么使用自定義指令
NG內(nèi)置了許多自定義指令,但是它們有時并不能滿足你的要求,這是需要我們創(chuàng)建自定義屬性。
二、自定義指令
接下來,我們來做一個小案例,當(dāng)鼠標(biāo)單擊加價后,列表項自動遞增,當(dāng)然列表也是通過指令自動添加的,它本就是一個空的div
<!DOCTYPE>
<!-- use module -->
<html ng-app="exampleApp">
<head>
<title>Angluar test</title>
<meta charset="utf-8"/>
<link rel="stylesheet" type="text/css" href="css/bootstrap.min.css">
<link rel="stylesheet" type="text/css" href="css/bootstrap-theme.min.css">
</head>
<body>
<dlv class="panel panel-default" ng-controller="defaultCtrl">
<div class="panel-heading">
<h3>Products</h3>
</div>
<div class="panel-body">
<!-- 點擊加價,價格遞增 -->
<button type="button" class="btn btn-primary" ng-click="incrementPrices()">加價</button>
</div>
<div class="panel-body">
<!-- 將products數(shù)據(jù)以一種無序列表的形式展示 -->
<!-- list-property="price | currency" 列表項單位本地化 -->
<div unorderlist="products" list-property="price | currency"></div>
</div>
</dlv>
<script type="text/javascript" src="js/angular.min.js"></script>
<script type="text/javascript">
angular.module("exampleApp", [])
.directive("unorderlist", function () {
// scope 作用域
// element 應(yīng)用該指令的元素
// attrs 使用該指令的元素的屬性
return function (scope, element, attrs) {
// attrs['unorderlist'] 獲取unorderlist屬性值,這里為products
// 獲取數(shù)據(jù)模型值,這里為scope.products
var data = scope[attrs['unorderlist']];
// 創(chuàng)建一個<ul>標(biāo)簽元素
var ul = angular.element("<ul>");
// 在應(yīng)用該指令的元素中添加<ul>
element.append(ul);
// 獲取listProperty屬性值,這里為price | currency
var expression = attrs['listProperty'];
// 判斷是否為數(shù)組
if (angular.isArray(data)) {
// 遍歷數(shù)據(jù)模型scope.products
for (var i = 0; i < data.length; i++) {
// 添加閉包,將i傳遞進(jìn)去
(function (index) {
// 創(chuàng)建一個<li>標(biāo)簽元素
var li = angular.element("<li>");
// 將<li>標(biāo)簽添加到<ul>中
ul.append(li);
// 監(jiān)聽器函數(shù),用$eval計算表達(dá)式和data[index]的值
var watcherFn = function (watchScope) {
return watchScope.$eval(expression, data[index]);
}
// 添加$watch監(jiān)聽器監(jiān)聽作用域的變化
scope.$watch(watcherFn, function (newValue, oldValue) {
// 更新li的值
li.text(newValue);
})
})(i);
}
}
}
})
.controller("defaultCtrl", function ($scope) {
// 數(shù)據(jù)模型
$scope.products = [
{ name: "Apples", category: "Fruit", price: 1.20, expiry: 10 },
{ name: "Bananas", category: "Fruit", price: 2.42, expiry: 7 },
{ name: "Pears", category: "Fruit", price: 2.02, expiry: 6 }
];
// 遞增價格
$scope.incrementPrices = function () {
for (var i = 0; i < $scope.products.length; i++) {
$scope.products[i].price++;
}
}
})
</script>
</body>
</html>
解析:
第一步:創(chuàng)建控制器,添加數(shù)據(jù)模型products和遞增價格incrementPrices()方法
第二步:自定義unorderlist標(biāo)簽,該標(biāo)簽的作用是:通過作用域數(shù)據(jù)模型的值,將其值以無序列表的方式展示出來
第三部:并且在單擊加價按鈕時,無序列表的值會依次遞增

三、使用jqLite工作
NG內(nèi)置了jqLite,它是JQuery的縮小版
<!DOCTYPE>
<!-- use module -->
<html ng-app="exampleApp">
<head>
<title>Angluar test</title>
<meta charset="utf-8"/>
<link rel="stylesheet" type="text/css" href="css/bootstrap.min.css">
<link rel="stylesheet" type="text/css" href="css/bootstrap-theme.min.css">
</head>
<body>
<dlv class="panel panel-default">
<!-- 使用自定義指令 -->
<ol dome-directive>
<li>Apples</li>
<ul>
<li>Bananas</li>
<li>Cherries</li>
<li>Oranges</li>
</ul>
<li>Pears</li>
<li>Oranges</li>
</ol>
</dlv>
<script type="text/javascript" src="js/angular.min.js"></script>
<script type="text/javascript">
angular.module("exampleApp", [])
.directive("domeDirective", function () {
return function (scope, element, attrs) {
// 找出element元素下所有的li,這里的element是調(diào)用者<ol>
var items = element.find("li");
// 要所有的li的font-weight為bold
items.css("font-weight", "bold");
// 遍歷li, 值為Oranges的字體顏色為red,其余為green
for (var i = 0; i < items.length; i++) {
if (items.eq(i).text() == "Oranges"){
items.eq(i).css("color", "red");
} else {
items.eq(i).css("color", "green");
}
}
// 打印出li的長度和字體顏色
console.log("Items length : " + items.length);
console.log("Color: " + items.css("color"));
}
})
</script>
</body>
</html>
解析:
第一步:自定義控制器,定義數(shù)據(jù)模型names
第二步:自定義指令,功能是將使用指令的元素下的所有l(wèi)i找出,并且更加值的不同賦給字體不同的顏色
第三步:在視圖中調(diào)用并且使用指令

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 深入講解AngularJS中的自定義指令的使用
- AngularJS創(chuàng)建自定義指令的方法詳解
- AngularJS使用自定義指令替代ng-repeat的方法
- AngularJS 自定義指令詳解及實例代碼
- AngularJS自定義指令實現(xiàn)面包屑功能完整實例
- AngularJS實現(xiàn)自定義指令與控制器數(shù)據(jù)交互的方法示例
- AngularJS 自定義指令詳解及示例代碼
- AngularJS自定義指令之復(fù)制指令實現(xiàn)方法
- AngularJS自定義指令詳解(有分頁插件代碼)
- 詳解angularJS自定義指令間的相互交互
- AngularJS實現(xiàn)自定義指令及指令配置項的方法
相關(guān)文章
AngularJS基礎(chǔ)學(xué)習(xí)筆記之表達(dá)式
AngularJS表達(dá)式用于應(yīng)用程序數(shù)據(jù)綁定到HTML。表達(dá)式都寫在雙括號就像{{表達(dá)式}}。表達(dá)式中的行為跟ng-bind指令方式相同。 AngularJS應(yīng)用表達(dá)式是純javascript表達(dá)式,并輸出它們被使用的數(shù)據(jù)在那里。2015-05-05
angular 數(shù)據(jù)綁定之[]和{{}}的區(qū)別
這篇文章主要介紹了angular 數(shù)據(jù)綁定之[]和{{}}的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-09-09
創(chuàng)建你的第一個AngularJS應(yīng)用的方法
這篇文章主要介紹了創(chuàng)建你的第一個AngularJS應(yīng)用的方法,AngularJS是一個非常具有人氣的JavaScript框架,需要的朋友可以參考下2015-06-06
解決angular 使用原生拖拽頁面卡頓及表單控件輸入延遲問題
這篇文章主要介紹了angular 中使用原生拖拽頁面卡頓及表單控件輸入延遲問題,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04
Angular實現(xiàn)的內(nèi)置過濾器orderBy排序與模糊查詢功能示例
這篇文章主要介紹了Angular實現(xiàn)的內(nèi)置過濾器orderBy排序與模糊查詢功能,涉及AngularJS過濾器、排序及字符串遍歷、查詢等相關(guān)操作技巧,需要的朋友可以參考下2017-12-12
探索angularjs+requirejs全面實現(xiàn)按需加載的套路
這篇文章主要探索了angularjs+requirejs全面實現(xiàn)按需加載的套路,圍繞angularjs提供的各種機(jī)制進(jìn)行研究,感興趣的小伙伴們可以參考一下2016-02-02
Angular中ng-repeat與ul li的多層嵌套重復(fù)問題
這篇文章主要介紹了Angular中ng-repeat與ul li的多層嵌套重復(fù)問題,需要的朋友可以參考下2017-07-07

