angularjs自定義過濾器demo示例
本文實(shí)例講述了angularjs自定義過濾器demo。分享給大家供大家參考,具體如下:
這個(gè)基于angularjs的過濾器是最近做的"信息管理學(xué)院實(shí)驗(yàn)室預(yù)約"項(xiàng)目中的一個(gè)小功能。
以下為數(shù)據(jù):
$scope['classes']=[{id:1,name:"H503",capacity:40,software:"photoshop,金蝶,AI",freeTime:"周一1-2-3,周五1-2-3,周一5-6,"},
{id:2,name:"H504",capacity:50,software:"chrome,金蝶,office,"
,freeTime:"周二1-2-3,周三3-4,周一5-6,"},
{id:3,name:"H505",capacity:60,software:"chrome,LOL,office,"
,freeTime:"周二1-2-3,周三3-4,周四7-8,"}
];
具體功能:
分別在兩個(gè)select選擇星期和課次,列表會(huì)即時(shí)根據(jù)條件更新。
完整代碼:
<!DOCTYPE html>
<html ng-app="myApp" >
<head>
<meta charset="utf-8">
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<div ng-controller="myCtrl">
<select ng-model="day">
<option selected="">周一</option>
<option>周二</option>
<option>周三</option>
<option>周四</option>
<option>周五</option>
</select>
<select ng-model="order">
<option selected="">1-2</option>
<option>1-2-3</option>
<option>3-4</option>
<option>1-2-3-4</option>
<option>5-6</option>
<option>7-8</option>
</select>
<ul>
<li ng-repeat="class in classes | myFiter:day:order">
<span>{{class.id}}</span>
<span>{{class.name}}</span>
<span>{{class.capacity}}</span>
<span>{{class.software}}</span>
</li>
</ul>
</select>
</div>
<script type="text/javascript">
var app = angular.module('myApp', []);
app.controller('myCtrl', function($scope) {
//假數(shù)據(jù)
$scope['classes']=[{id:1,name:"H503",capacity:40,software:"photoshop,金蝶,AI",freeTime:"周一1-2-3,周五1-2-3,周一5-6,"},
{id:2,name:"H504",capacity:50,software:"chrome,金蝶,office,"
,freeTime:"周二1-2-3,周三3-4,周一5-6,"},
{id:3,name:"H505",capacity:60,software:"chrome,LOL,office,"
,freeTime:"周二1-2-3,周三3-4,周四7-8,"}
];
//select的默認(rèn)值
$scope.order="1-2";
$scope.day="周一";
});
//自定義過濾器
app.filter('myFiter',function()
{
return function(input,day,order)
{
var time=day+order;
var output=[];
for(var i=0;i<input.length;i++)
{
var n=input[i].freeTime.indexOf(time);
// console.log(n);
// console.log(input[i].freeTime.charAt(n+time.length));
if(n!=-1)//如果能找到
{
if(input[i].freeTime.charAt(n+time.length)==',')
//這樣做是為了防止1-2與1-2-3是一樣的結(jié)果
output.push(input[i]);
}
}
return output;
}
})
</script>
</body>
</html>
運(yùn)行效果:

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
總結(jié):filter可以理解為一個(gè)帶參數(shù)的函數(shù),它把一個(gè)對(duì)象進(jìn)行一些處理,然后把處理后的對(duì)象返回。不過我認(rèn)為以上的這個(gè)算法有待優(yōu)化。
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對(duì)大家AngularJS程序設(shè)計(jì)有所幫助。
相關(guān)文章
AngularJS實(shí)現(xiàn)用戶登錄狀態(tài)判斷的方法(Model添加攔截過濾器,路由增加限制)
這篇文章主要介紹了AngularJS實(shí)現(xiàn)用戶登錄狀態(tài)判斷的方法,通過Model添加攔截過濾器,路由增加限制實(shí)現(xiàn)針對(duì)登陸狀態(tài)的判斷功能,需要的朋友可以參考下2016-12-12
AngularJS中update兩次出現(xiàn)$promise屬性無法識(shí)別的解決方法
最近在工作中用AngularJS中update了兩次之后發(fā)現(xiàn)$promise屬性無法識(shí)別了,后來通過查找相關(guān)的資料終于解決了,想著記錄下方便自己或者有需要的朋友,所以本文主要介紹了AngularJS中update兩次出現(xiàn)了$promise屬性無法識(shí)別的解決方法,需要的朋友可以參考借鑒。2017-01-01
Angular4學(xué)習(xí)教程之HTML屬性綁定的方法
這篇文章主要給大家介紹了關(guān)于Angular4學(xué)習(xí)教程之HTML屬性綁定的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01
詳解Angular系列之變化檢測(cè)(Change Detection)
這篇文章主要介紹了詳解Angular系列之變化檢測(cè)(Change Detection),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
AngularJS中控制器函數(shù)的定義與使用方法示例
這篇文章主要介紹了AngularJS中控制器函數(shù)的定義與使用方法,結(jié)合具體實(shí)例形式分析了AngularJS控制器函數(shù)的定義、綁定及相關(guān)使用技巧,需要的朋友可以參考下2017-10-10
Angular.JS實(shí)現(xiàn)無限級(jí)的聯(lián)動(dòng)菜單(使用demo)
這篇文章主要介紹了Angular.JS中實(shí)現(xiàn)無限級(jí)聯(lián)動(dòng)菜單的使用示例,本文是在之前的一篇文章的基礎(chǔ)上進(jìn)行的幾個(gè)demo分享,有需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02
詳解Angular Reactive Form 表單驗(yàn)證
本文我們將介紹 Reactive Form 表單驗(yàn)證的相關(guān)知識(shí),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07
Angularjs中數(shù)據(jù)綁定的實(shí)例詳解
這篇文章主要介紹了Angularjs中數(shù)據(jù)綁定的實(shí)例詳解的相關(guān)資料,這里提供簡(jiǎn)單實(shí)例,大家可以參考下,希望通過本文可以掌握這部分內(nèi)容,需要的朋友可以參考下2017-08-08
發(fā)布Angular應(yīng)用至生產(chǎn)環(huán)境的方法
這篇文章主要介紹了發(fā)布Angular應(yīng)用至生產(chǎn)環(huán)境的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12

