㈠ angularjs怎麼獲取過濾器選擇後的數據
AngularJS的內置過濾器使用方法:
一個過濾器,不帶參數的情況
{{expression | filter}}
一個過濾器,帶參數的情況
{{expression | filter:arguments}}
一個過濾器,帶多個參數的情況
{{expression | filter: arg1: arg2: ...}}
多個過濾器,不帶參數的情況
{{expression | filter1 | filter2 | ...}}
分別使用以下AngularJS的內置過濾器
currency
currency允許我們設置自己的貨幣符號,默認情況下會採用客戶端所處區域的貨幣符號。
可以這樣使用:{{ 3600 | currency: "$¥"}}
返回結果為$¥123.00
online code點擊預覽
number
number過濾器將數字格式化成文本,它的參數是可選的,用來控制小數點後的截取位數
如果傳入的是一個非數字字元,會返回空字元串
可以這樣使用:{{ 3600 | number:2}}
返回結果為:3,600.00
online code點擊預覽
lowercase
lowercase將字元串轉換為小寫
可以這樣使用:{{ "HEllo" | lowercase}}
返回結果為:hello
online code點擊預覽
uppercase
uppercase將字元串轉換為大寫
可以這樣使用:{{ "HEllo" | uppercase}}
返回結果為:HELLO
online code點擊預覽
㈡ 在什麼地方使用angularjs過濾器
一、在視圖模板(View Template)中使用
在表達式中應用Filters (過濾器)
需要遵循格式如下:
{{ expression | filter }} 即 {{ 表達式 | 過濾器 }}
例如:{{ 12 | currency }} 輸出為 $12.00
在輸出結果中應用Filters (過濾器)
通俗點講就是Filter的疊加--前一filter的輸出結果作為後一filter的輸入數據源.
需要遵循格式如下:
{{ expression | filter1 | filter2 | ... }} 即 表達式(expression)使用filter1過濾後再使用filter2過濾...
帶參數的Filter
Filter後面可以跟一個或多個參數,用來幫助實現特殊要求、需求的filter.
需要遵循格式如下:
{{ expression | filter:argument1:argument2:... }}
示例: {{ 1234 | number:2 }} = 1,234.00
END
二、使用 AngluarJS 內置Filter
AngularJS為我們提供了9個內建的過濾器
分別是currency, date, filter, json, limitTo, uppercase, lowercase, number, orderBy。
具體的用法在AngularJS的文檔中都有詳細說明。下面只說幾個常用的。
currency filter(貨幣過濾器)
currency – 用來將變數轉換成貨幣表現形式
如:{{ amount | currency}}
uppercase/lowercase filter(字母大小寫filter)
如:
{{ "lower cap string" | uppercase }}
<input ng-model="userInput"> Uppercased: {{ userInput | uppercase }}
date filter (日期filter)
如:
{{ 1304375948024 | date }}
{{ 1304375948024 | date:"MM/dd/yyyy @ h:mma" }}
json filter
如:
{{ {foo: "bar", baz: 23} | json }}
END
在controllers, services和drictives中使用filter
1
可以在AngularJS的controller, service或者driective中使用filter, 這時候你需要將依賴的filter名字加入到controller, service或者directive的依賴中去。
2
在controller中直接使用filter, 這樣controller可以根據自身需要而適時調用filter
END
三、自定義filter(過濾器)
1
AngularJS編寫自定義過濾器的形式和AngularJS的factory service非常相像,一定記得它返回一個對象或者是一個函數即可,編寫的時候,只需要一個帶有一個以上參數的函數即可。
2
格式大致如:
app.filter('filter(過濾器)名稱',function(){
return function(需要過濾的對象,過濾器參數1,過濾器參數2,...){
//...執行業務邏輯代碼
return 處理後的對象;
}
});
㈢ angularjs中有多個過濾器使用方法
一、在視圖模板(View Template)中使用
在表達式中應用Filters (過濾器)
需要遵循格式如下:
{{ expression | filter }} 即 {{ 表達式 | 過濾器 }}
例如:{{ 12 | currency }} 輸出為 $12.00在輸出結果中應用Filters (過濾器)
通俗點講就是Filter的疊加--前一filter的輸出結果作為後一filter的輸入數據源.
需要遵循格式如下:
{{ expression | filter1 | filter2 | ... }} 即 表達式(expression)使用filter1過濾後再使用filter2過濾...
帶參數的Filter
Filter後面可以跟一個或多個參數,用來幫助實現特殊要求、需求的filter.
需要遵循格式如下:
{{ expression | filter:argument1:argument2:... }}
示例: {{ 1234 | number:2 }} = 1,234.00END
二、使用 AngluarJS 內置Filter
AngularJS為我們提供了9個內建的過濾器
分別是currency, date, filter, json, limitTo, uppercase, lowercase, number, orderBy。
具體的用法在AngularJS的文檔中都有詳細說明。下面只說幾個常用的。
currency filter(貨幣過濾器)
currency – 用來將變數轉換成貨幣表現形式
如:{{ amount | currency}}
uppercase/lowercase filter(字母大小寫filter)如:
{{ "lower cap string" | uppercase }}
<input ng-model="userInput"> Uppercased: {{ userInput | uppercase }}
date filter (日期filter)
如:
{{ 1304375948024 | date }}
{{ 1304375948024 | date:"MM/dd/yyyy @ h:mma" }}
json filter
如:
{{ {foo: "bar", baz: 23} | json }}
END
在controllers, services和drictives中使用filter1可以在AngularJS的controller, service或者driective中使用filter, 這時候你需要將依賴的filter名字加入到controller, service或者directive的依賴中去。
2在controller中直接使用filter, 這樣controller可以根據自身需要而適時調用filterEND
三、自定義filter(過濾器)
1AngularJS編寫自定義過濾器的形式和AngularJS的factory service非常相像,一定記得它返回一個對象或者是一個函數即可,編寫的時候,只需要一個帶有一個以上參數的函數即可。
2格式大致如:
app.filter('filter(過濾器)名稱',function(){return function(需要過濾的對象,過濾器參數1,過濾器參數2,...){//...執行業務邏輯代碼return 處理後的對象;
}
});
㈣ Angularjs過濾器使用詳解
給大家介紹下什麼是
AngularJS?
AngularJS是一個為動態WEB應用設計的結構框架。它能讓你使用HTML作為模板語言,通過擴展HTML的語法,讓你能更清楚、簡潔地構建你的應用組件。它的創新點在於,利用數據綁定和依賴注入,它使你不用再寫大量的代碼了。這些全都是通過瀏覽器端的Javascript實現,這也使得它能夠完美地和任何伺服器端技術結合。
AngularJS是為了克服HTML在構建應用上的不足而設計的。HTML是一門很好的為靜態文本展示設計的聲明式語言,但要構建WEB應用的話它就顯得乏力了。所以我做了一些工作(你也可以覺得是小花招)來讓瀏覽器做我想要的事。
AngularJS提供了過濾器來對輸入輸出數據格式化。下面開始給大家介紹Angularjs過濾器使用,一起看看吧
•在html文件中和在js文件中使用
$scope.form_time
=
$filter('date')($scope.time,
'yyyy-MM-dd
HH:mm:ss');
<p>{{time
|
date:
'yyyy-MM-dd
HH:mm:ss'}}</p>
•內部過濾器和自定義過濾器
.filter('my_data_format',[function(){
return
function(data,str,sss){
console.log('data:
',data,'
str:
',str,'
sss:
',arguments[2]);
}
}]);
//var1就是第一個參數data,
123是第二個參數str,
this是第三個參數
<p>{{var1
|
my_data_format
:
123
:
'this'}}</p>
//對傳入的數據進行處理
.filter('my_data_format',[function(){
return
function(data,str){
var
arr=[];
angular.forEach(data,
function(one_list){
if(one_list.status
==
str){
arr.push(one_list);
}
});
return
arr;
}
}]);
//過濾器可以用在綁定的值中,也可以用在ng-if="(lists
|
my_data_format:
'2').length>0",
和ng-show等;類似的表達式中。作為判斷語句
<p
ng-repeat
=
"list
in
lists">姓名:{{list.name}},人數{{(lists
|
my_data_format:
'2').length}}</p>
㈤ angular寫的過濾器 怎麼引入
1.過濾器是用來格式化需要展示給用戶的數據,AngularJS中含有實用的內置過濾器可以使用,也支持用戶進行自定義過濾器;
2.過濾器調用方式:
(1) 在HTML的模板中綁定符合{{}} 內通過 | 符號來調用過濾器; 比如{{ name | uppercase }} ------將name字元串中的每個字元轉為大寫字母;
(2) 在JavaScript中可以通過$filter 來調用過濾器,比如:
[javascript] view plain
app.controller("demoController",['$scope','$filter',function($scope,$filter){
$scope.name = $filter("uppercase")('ari');
}]);
(3) 在HTML中使用過濾器時,如需要傳遞參數給過濾器,則需要在過濾器後面加冒號即可,若有多個參數,則在每個參數後面加入冒號即可,比如 {{ 123.4567 | number : 2}} 頁面展示為 123.46
3.angularJS 提供的內置過濾器:
(1) currency: 可以將一個數值格式化為貨幣格式,默認的貨幣符號是當前客戶端所處區域的貨幣符號;
(2)date:將日期格式化為需要的格式,具體的格式參考其API;
(3) filter:從給定數組中選擇一個子集,並將其生成一個新數組返回。filter過濾器的第一個參數可以是字元串、對象或是一個用來從數組中選擇元素函數,傳入不同類型時表現:
1) 字元串:返回所有包含這個字元串的元素,如想返回不包含該字元串的所有元素,則在參數之前加 ! ;
2) 對象:AngularJS會將待過濾對象的屬性同這個對象中的同名屬性進行比較,若屬性值是字元串就會判斷是否包含該字元串;若希望對全部屬性進行對比,將$作為鍵名;
3) 函數: 對待過濾數組的每個元素執行此函數,返回非假值的元素會出現在新的數組中並返回;
filter的第二個參數可以是:
1)true: 用angular.equals(excepted,actual)對兩個值進行嚴格比較;
2) false:進行區分大小寫的子字元串比較;
3)函數:運行這個函數,如果返回真值就接受這個元素;
(4) json:將一個JSON或JavaScript對象轉換成字元串;
(5) limitTo :根據傳入的參數生成一個新的數組或字元串,新的數組或字元串的長度取決於傳入的參數,通過傳入參數的正負值來控制從前面還是後面進行截取;
如果傳入的長度大於被過濾的數組或字元串的長度,則整個數組或字元串都會被返回;
{{ San is very people | limitTo : 3}} ----> San {{ San is very people | limitTo : -3}} ---->ple
(6)lowercase 將過濾字元串轉為小寫字母; uppercase 將過濾字元串轉為大寫字母;
(7) number :將數字格式化成文本,第二個參數是可選,用於控制小數點後截取的位數; 如果傳入的是非數字字元,則返回空字元串;
(8) orderBy:用表達式對指定的數組進行排序,可以接受兩個參數,第一個參數是必須的,第二個參數是可選,第一個參數的情況:
1) 函數:當第一個參數是函數時,該函數會被當作待排序對象的getter方法;
2)字元串:對這個字元串進行解析的結果將決定數組元素的排序方式,可以使用+ 或 - 來強制進行升序和降序;
3)數組:在排序表達式中使用數組元素作為謂詞; 第二個參數用來控制排序的方向;
4.自定義過濾器:
此過濾器用來定義一個名為myFilter的過濾器,作用是將傳入的字元串的首字母轉為大寫字母;
[javascript] view plain
angular.mole("testFilter",[]).filter("myFilter",function(){
return function(input) {
if (input) {
return input[0].toUpperCase() + input.slice(1);
}
}
});
5.表單驗證:
(1) 若想要屏蔽瀏覽器對表單的默認驗證行為,則在表單元素上添加 novalidate標記,若想使用angularJS 的表單驗證功能,需要保證form有name屬性;
(2) input上可以使用的驗證選項:
1)required:驗證當前input是否有值,必填項;
2) ng-minlength/ng-maxlength:當前input能輸入的最大長度和最小長度; <input name="text" ng-minlength="2" ng-maxlength="20"/>
3) ng-pattern :模式匹配,用來確保輸入能夠匹配指定的正則表達式;
4) email:驗證輸入的內容是否是電子郵件,<input type="email" name="email"/>
5) number:驗證輸入的內容是否是數字 <input type="number" name="age"/>
6) URL:驗證輸入的內容是否是URL <input type="url" name="homespace"/>
在javaScript中可以使用這些屬性去對表單做出實時響應 通過formName.inputFieldName.property格式訪問屬性:
1) formName.inputFieldName.$pristine:用來判斷用戶是否修改了表單,若未修改則返回true,若修改過,則返回false;
2) formName.inputFieldName.$dirty:只用用戶修改過表單,無論輸入是否通過驗證,該值都返回true;
3) fornName.inputFieldName.$valid:用來判斷表單的內容是否合法,若表單內容是合法的則返回true;
4) fornName.inputFieldName.$invalid:用來判斷表單的內容是否不合法,若表單內容是不合法的則返回true;
5) fornName.inputFieldName.$error:用來判斷表單所有的驗證內容以及內容是否合法,如果驗證失敗,則屬性值為true,若輸入欄位的值通過驗證則返回false;
(3) $parsers:
當用戶同控制器進行交互並且ngModelController中的$setViewValue()方法被調用時,$parsers數組中的函數會以流水線的形式被逐個調用,第一個調用值會變傳入到第二個$parse中;調用函數時,可以使用$setValidity()函數去設置表單的合法性;
(4) $formatters:
當綁定的ngModel值發生變化,並經過$parsers數組中解析器處理後,這個值會被創遞給$formatters流水線,此函數可以修改並格式化這些值;
(3) ngMessages( 在AngularJS 1.3+以上版本中才包含此指令)
1)ngMessages是angularJs的一個獨立模塊,故需要手動載入 指令為 $ bower install --save angular-messages或在angular官網上下載此文件,然後通過html引入;
2)ngMessages還需要作為引用程序的依賴模塊引入,比如angular.mole("myApp",[ngMessages]);
㈥ angularjs 控制器中怎樣使用過濾器
內置過濾器也可以在js文件中使用,只要在angularjs組件定義時注入$filter組件,即可在內代碼中使用過容濾器。
app.controller('testC',['$scope','$filter',function($scope,$filter){
$scope.num = $filter('currency')(123534);
$scope.date = $filter('date')(new Date());
]}
㈦ angularjs過濾器在js中怎麼用
一、在視圖模板(View Template)中使用 在表達式中應用Filters (過濾器) 需要遵循格式如下: {{ expression | filter }} 即 {{ 表達式 | 過濾器 }} 例如:{{ 12 | currency }} 輸出為 $12.00在輸出結果中應用Filters (過濾器) 通俗點講就是...
㈧ angualar js怎麼加過濾
系統的學習了一下angularjs,發現angularjs的有些思想根php的模塊smarty很像,例如數據綁定,filter。如果對smarty比較熟悉的話,學習angularjs會比較容易一點。這篇簡單說一下angularjs的filter功能,angularjs的filter功能可分為二種,一種是內置的過濾器,一種是自定義的。
一,內置的過濾器
1,uppercase,lowercase大小轉換
{{ "lower cap string" | uppercase }} //結果:LOWER CAP STRING{{ "TANK is GOOD" | lowercase }} //結果:tank is good
|這里的豎線是一種管道功能,如果對linux比較熟悉的話,這塊的|根linux的管道功能,基本是一樣的
2,json格式化
{{ {foo: "bar", baz: 23} | json }} //結果:{ "foo": "bar", "baz": 23 }
注意:bza沒格式前是沒有雙引號的,格式化後就轉換成了json數據了。
3,date格式化
{{ 1304375948024 | date }} //結果:May 3, 2011{{ 1304375948024 | date:"MM/dd/yyyy @ h:mma" }} //結果:05/03/2011 @ 6:39AM{{ 1304375948024 | date:"yyyy-MM-dd hh:mm:ss" }} //結果:2011-05-03 06:39:08
4,number格式化
{{ 1.234567 | number:1 }} //結果:1.2{{ 1234567 | number }} //結果:1,234,567
5,currency貨幣格式化
{{ 250 | currency }} //結果:$250.00{{ 250 | currency:"RMB ¥ " }} //結果:RMB ¥ 250.00
6,filter查找
{{ [{"age": 20,"id": 10,"name": "iphone"},{"age": 12,"id": 11,"name": "sunm xing"},{"age": 44,"id": 12,"name": "test abc"}] | filter:'s'}} //查找含有有s的行 //上例結果:[{"age":12,"id":11,"name":"sunm xing"},{"age":44,"id":12,"name":"test abc"}] {{ [{"age": 20,"id": 10,"name": "iphone"},{"age": 12,"id": 11,"name": "sunm xing"},{"age": 44,"id": 12,"name": "test abc"}] | filter:{'name':'iphone'} }} //查找name為iphone的行 //上例結果:[{"age":20,"id":10,"name":"iphone"}]
7,limitTo字元串,對像的截取
{{ "i love tank" | limitTo:6 }} //結果:i love{{ "i love tank" | limitTo:-4 }} //結果:tank {{ [{"age": 20,"id": 10,"name": "iphone"},{"age": 12,"id": 11,"name": "sunm xing"},{"age": 44,"id": 12,"name": "test abc"}] | limitTo:1 }} //結果:[{"age":20,"id":10,"name":"iphone"}]
8,orderBy對像排序
{{ [{"age": 20,"id": 10,"name": "iphone"},{"age": 12,"id": 11,"name": "sunm xing"},{"age": 44,"id": 12,"name": "test abc"}] | orderBy:'id':true }} //根id降序排 {{ [{"age": 20,"id": 10,"name": "iphone"},{"age": 12,"id": 11,"name": "sunm xing"},{"age": 44,"id": 12,"name": "test abc"}] | orderBy:'id' }} //根據id升序排
二,自定filter功能
我找了一個基本angularjs的mvc框架,phonecat,自定義filter也是在這基礎寫的,這個框架挺好用的。
1,filters.js添加一個mole
angular.mole('tanktest', []).filter('tankreplace', function() { return function(input) { return input.replace(/tank/, "=====") };});
2,app.js中載入這個mole
var phonecatApp = angular.mole('phonecatApp', [ 'ngRoute', 'phonecatControllers', 'facebookControllers', 'tanktest']);
3,html中調用
{{ "TANK is GOOD" | lowercase |tankreplace}} //結果:===== is good
注意:| lowercase |tankreplace管道命令可以有多個
三、filter的兩種使用方法
1. 在模板中使用filter
我們可以直接在{{}}中使用filter,跟在表達式後面用 | 分割,語法如下:
{{ expression | filter }}
也可以多個filter連用,上一個filter的輸出將作為下一個filter的輸入(怪不得這貨長的跟管道一個樣。。)
{{ expression | filter1 | filter2 | ... }}
filter可以接收參數,參數用 : 進行分割,如下:
{{ expression | filter:argument1:argument2:... }}
除了對{{}}中的數據進行格式化,我們還可以在指令中使用filter,例如先對數組array進行過濾處理,然後再循環輸出:
<span ng-repeat="a in array | filter ">
2. 在controller和service中使用filter
我們的js代碼中也可以使用過濾器,方式就是我們熟悉的依賴注入,例如我要在controller中使用currency過濾器,只需將它注入到該controller中即可,代碼如下:
app.controller('testC',function($scope,currencyFilter){ $scope.num = currencyFilter(123534);}
在模板中使用{{num}}就可以直接輸出$123,534.00了!在服務中使用filter也是同樣的道理。
此時你可能會有疑惑,如果我要在controller中使用多個filter,難道要一個一個注入嗎,這豈不太費勁了?小兄弟莫著急~ng提供了一個$filter服務可以來調用所需的filter,你只需注入一個$filter就夠了,使用方法如下:
app.controller('testC',function($scope,$filter){ $scope.num = $filter('currency')(123534);$scope.date = $filter('date')(new Date());}
可以達到同樣的效果。好處是你可以方便使用不同的filter了。
㈨ angularjs過濾器相關問題
先來看看這些內置過濾器使用方法:
一個過濾器,不帶參數的情況
{{expression | filter}}
一個過濾器,帶參數的情況
{{expression | filter:arguments}}
一個過濾器,帶多個參數的情況
{{expression | filter: arg1: arg2: ...}}
多個過濾器,不帶參數的情況
{{expression | filter1 | filter2 | ...}}
下面我們分別使用以下AngularJS的內置過濾器
currency
currency允許我們設置自己的貨幣符號,默認情況下會採用客戶端所處區域的貨幣符號。
可以這樣使用:{{ 3600 | currency: "$¥"}}
返回結果為$¥123.00
online code點擊預覽
number
number過濾器將數字格式化成文本,它的參數是可選的,用來控制小數點後的截取位數
如果傳入的是一個非數字字元,會返回空字元串
可以這樣使用:{{ 3600 | number:2}}
返回結果為:3,600.00
online code點擊預覽
lowercase
lowercase將字元串轉換為小寫
可以這樣使用:{{ "HEllo" | lowercase}}
返回結果為:hello
online code點擊預覽
uppercase
uppercase將字元串轉換為大寫
可以這樣使用:{{ "HEllo" | uppercase}}
返回結果為:HELLO
online code點擊預覽
json
json過濾器可以將一個JSON或者JavaScript對象轉換成字元串。
這個過濾器對調試相當有用
可以這樣使用:{{ {"name":"dreamapple","language":"AngularJS"} | json}}
返回結果為:{ "name": "dreamapple", "language": "AngularJS" }
online code點擊預覽
date
date過濾器將日期過濾成你想要的格式,這個實在是很好的過濾器。
這個過濾器用法很多我這里列舉幾種常用的
{{ today | date: "yyyy - mm - dd"}}
結果為:2015 - 15 - 13
{{ today | date: "yyyy - mm - dd HH:mm::ss"}}
結果為:2015 - 18 - 13 20:18::38
[online code](2015 - 18 - 13 20:18::38)
還有三個內置的過濾器,但是使用稍微復雜一點,放在下一篇文章中我們大家一起探討吧
㈩ angularjs自定義過濾器怎麼寫
過濾器(filter)正如其名,作用就是接收一個輸入,通過某個規則進行處理,然後返回處回理後的結果。主要答用在數據的格式化上,例如獲取一個數組中的子集,對數組中的元素進行排序等。ng內置了一些過濾器,它們是:currency(貨幣)、date(日期)、filter(子串匹配)、json(格式化json對象)、limitTo(限制個數)、lowercase(小寫)、uppercase(大寫)、number(數字)、orderBy(排序)。總共九種。除此之外還可以自定義過濾器,這個就強大了,可以滿足任何要求的數據處理。
AngularJS中為我們提供了一些內置的過濾器,這里列舉一些自定義過濾器的場景。