1. 如何使用vuejs過濾器
在這個教程中,我們將會通過幾個例子,了解和學習VueJs的過濾器。我們參考了一些比較完善的過濾器,比如orderBy 和 filterBy。而且我們可以鏈式調用過濾器,一個接一個過濾。因此,我們可以定義我們自己的過濾器在我們的Vue實例中。
閱讀這個教程的前提是你對Vue已經有了基本的語法基礎。
VueJs中的過濾器基礎
過濾器是一個通過輸入數據,能
2. 如何使用vuejs過濾器
在user-list組件中我們需要遍歷聯系人列表,filter_key用來傳給該組件,和搜索欄組件一樣,也用props接收一下,並且在裡面插入要過濾的內容,
filterBy是返回過濾後的數組,orderBy是排序,前者的使用方法是filterBy 一個key(欄位),in xxx 就是指搜索欄位,這里需要注意的是in後面跟的必須是obj裡面的key,因為我們的需求是同時保證輸入漢字或者拼音都能查詢,所以in後面跟的是okr_owner和user.u_name(這是vue渲染的數據,我們展示該聯系人用的是裡面的u_name,okr_owner則為拼音),下面附上數據結構。對於在搜索時如何去掉這些字母索引,我們只需要在通訊錄頁面中的<user-list>加入一個欄位,然後使用watch來監聽一下key_word即可。
3. 怎麼把兩個js 數組過濾合並成一個數組謝謝
首先考慮的是兩個數組之間靠什麼來關聯:
根據newArr得出: province的id對應的city裡面的pid;
所以遍歷數組時候合並的邏輯: id ==pid.然後合為新數組的一個元素。
var newArr=[];
function combineArr(arr1, arr2){
var len = arr1.length;
for(var i=0; i<len; i++){
if(arr1[i].id == arr2[i].pid){
var obj = {};
obj['name']=arr1[i].name;
obj['city'] = arr2[i].name;
newArr.push(obj);
}
return newArr;
}
}
4. 請教AngularJs如何在js當中將json和orderBy過濾器進行連著傳參...
需求是把json和orderBy這兩個過濾器寫到一個js語句當中,先進行或者最後以回json的格答式輸出,再以age進行由小到大的排序,這樣在一條js語句當中可以實現:
<script>
var modelOne=angular.mole('myapp', []);
m1.controller('Aaa', ['$scope','$filter',function($scope,$filter){
var arr=[{"color":"zred","age":"60"},{"color":"cred","age":"40"},{"color":"dred","age":"90"},{"color":"bred","age":"20"},{"color":"ered","age":"80"}];
$scope.orderByarr=$filter("orderBy")(arr,"age");
}]);
</script>
再上html部分
<body ng-app="myapp">
<div ng-controller="Aaa">
<pre>{{orderBy}}</pre>
</div>
</body>;
5. js中數組可以使用filter過濾,但如果是json對象要怎麼過濾json對象是沒有filter方法的吧
過濾器(filter)正如其名,作用就是接收一個輸入,通過某個規則進行內處理,然後返容回處理後的結果。主要用在數據的格式化上,例如獲取一個數組中的子集,對數組中的元素進行排序等。ng內置了一些過濾器,它們是:currency(貨幣)、date(日期)、filter(子串匹配)、json(格式化json對象)、limitTo(限制個數)、lowercase(小寫)、uppercase(大寫)、number(數字)、orderBy(排序)。總共九種。除此之外還可以自定義過濾器,這個就強大了,可以滿足任何要求的數據處理。AngularJS中為我們提供了一些內置的過濾器,這里列舉一些自定義過濾器的場景。
6. 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>
7. 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 處理後的對象;
}
});
8. 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)
還有三個內置的過濾器,但是使用稍微復雜一點,放在下一篇文章中我們大家一起探討吧
9. angularjs過濾器在js中怎麼用
一、在視圖模板(View Template)中使用 在表達式中應用Filters (過濾器) 需要遵循格式如下: {{ expression | filter }} 即 {{ 表達式 | 過濾器 }} 例如:{{ 12 | currency }} 輸出為 $12.00在輸出結果中應用Filters (過濾器) 通俗點講就是...