导航:首页 > 净水问答 > angularjs时间戳过滤器

angularjs时间戳过滤器

发布时间:2021-12-19 23:18:36

『壹』 angularjs怎么用过滤器筛选日期

ng-repeat="ramCount in ramCountList track by $index | orderBy: ramCount" track by $index 这个是过滤重复值 ramCount是数字类型的,然后按照专ramCount的值进行属升排序

『贰』 angularjs自定义过滤器怎么写

过滤器(filter)正如其名,作用就是接收一个输入,通过某个规则进行处理,然后返回处回理后的结果。主要答用在数据的格式化上,例如获取一个数组中的子集,对数组中的元素进行排序等。ng内置了一些过滤器,它们是:currency(货币)、date(日期)、filter(子串匹配)、json(格式化json对象)、limitTo(限制个数)、lowercase(小写)、uppercase(大写)、number(数字)、orderBy(排序)。总共九种。除此之外还可以自定义过滤器,这个就强大了,可以满足任何要求的数据处理。
AngularJS中为我们提供了一些内置的过滤器,这里列举一些自定义过滤器的场景。

『叁』 angularjs $filter过滤器问题

推荐使用angular-ui-grid:
controller:
varapp=angular.mole('app',['ngTouch','ui.grid','ui.grid.pagination']);

app.controller('MainCtrl',['$scope','$http',function($scope,$http){
$scope.gridOptions1={
paginationPageSizes:[25,50,75],
paginationPageSize:25,
columnDefs:[
{name:'name'},
{name:'gender'},
{name:'company'}
]
};
}]);

html:
<divui-grid="gridOptions1"ui-grid-paginationclass="grid"></div>

『肆』 angularjs自定义的过滤器只能用一次吗

这个只能自己写过滤方法版了权
function unique(arr, key){

var tempArr = arr;

for(var i = 0;i < tempArr.length;i++){

for(var j = 0;j< tempArr.length;j++){

if(tempArr[i][key] == tempArr[j][key]){

arr.splice(j,1);

}

}

}

return arr;
}
unique($scope.items,'name')

『伍』 angularjs 在未登录时,如何拦截

http拦截,即$http服务允许我们与服务端交互,有时候我们希望在发出请求之前以及收到响应之后做些事情。
$httpProvider包含了一个interceptors的数组。

我们这样创建一个interceptor。
app.factory('myInterceptor', ['$log', function($log){
$log.debug('');

var myInterceptor = {};

return myInterceptor;
}])

接着注册interceptor.
app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('myInterceptor');
}])

以下是$http拦截的一些例子。

■ 拦截器中的异步操作
app.factory('myInterceotpr','someAsyncServcie', function($q, someAsyncServcie){
var requestInterceptor = {
request: function(config){
var deferred = %q.defer();
someAsyncService.doAsyncOperation().then(function(){
...
deferred.resolve(config);
}, function(){
...
deferred.resolve(config);
})
return deferred.promise;
}
};

return requestInterceptor;
})

以上,是一个请求拦截,做了一个异步操作,根据异步操作的结果来更新config。

当然也有响应拦截。
app.factory('myInterceptor',['$q', 'someAsyncService', function($q, someAsyncSercice){
var responseInterceptor = {
response: function(response){
var deferred = $q.defer();
someAsyncService.doAsyncOperation().then(function(response){
...
deferred.resolve(response);
}, function(response){
...
deferred.resolve(response);
})
return deferred.promise;
}
};
return responseInterceptor;
}])

■ Session拦截,请求拦截

服务端有2种类型的验证,一个是基于cookie的,一种是基于token的。对于基于token验证,当用户登录,获取一个来自服务端的token,这个token在每一次请求时发送给服务端。

创建一个有关session的injector:
app.factory('sessionInjector',['SessionService', function(SessionService){
var sessionInjector = {
request: function(config){
if(!SessionService.isAnonymous){
config.headers['x-session-token'] = SessionService.token;
}
return config;
}
};

return sessionInjector;
}])

可见,把从服务端返回的token放在了config.headers中。

注册injector:

app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('sessionInjector');
}])

发出一个请求:

$http.get('');

拦截前大致是:

{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*"
}
}

拦截后,在headers中多两个一个x-session-token字段:

{
"transformRequest":[null],
"transformResponse":[null],
"method":"GET",
"url":"",
"headers":{
"Accept": "application/json, text/plain,*/*",
"x-session-token":......
}
}

■ 时间戳,请求和响应拦截

app.factory('timestampMarker',[function(){
var timestampMarker = {
request:function(config){
config.requestTimestamp = new Date().getTime();
return config;
},
response: function(response){
response.config.responseTimestamp = new Date().getTime();
return config;
}
};

return timestampMarker;
}])

以上,在请求和响应时拦截,在config.requestTimestamp和config.responseTimestamp赋上当前的时间。

注册拦截器:

app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('timestampMarker');
}])

然后在运用的时候可以算出请求响应所耗去的时间。

$http.get('').then(function(response){
var time = response.config.responseTime - response.config.requestTimestamp;
console.log('请求耗去的时间为 ' + time);
})

■ 请求错误恢复,请求拦截

模拟一个请求拦截的错误情形

app.factory('requestRejector',['$q', function($q){
var requestRejector = {
request: function(config){
return $q.reject('requestRejector');
}
};
return requestRejector;
}])

拦截请求错误:

app.factory('requestRecoverer',['$q', function($q){
var requestRecoverer = {
requestError: function(rejectReason){
if(rejectReason === 'requestRejector'){
//恢复请求
return {
transformRequest:[],
transformResponse:[],
method:'GET',
url:'',
headers:{
Accept:'application/json, text/plain, */*'
}
};
} else {
return $q.reject(rejectReason);
}
}
};

return requestRecoverer;
}])

注册拦截器:

?

app.config(['$httpProvider', function($httpProvider){
$httpProvider.interceptors.push('requestRejector');
$httpProvider.interceptors.push('requestRecoverer');
}])

■ Session错误

app.factory('sessionRecoverer',['$q','$injector',function($q, $injector){
var sessionRecoverer = {
responseError: function(response){
//如果Session过期
if(response.status == 419){
var SessionService = $injector.get('SessionService');
var $http = $injector.get('$http');
var deferred = $q.defer();

//创建一个新的session
SessionService.login().then(deferred.resolve, deferred.reject);

return deferred.promise.then(function(){
reutrn $http(response.config);
})
}
return $q.reject(response);
}
};

return sessionRecoverer;
}])

『陆』 请教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>;

『柒』 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内置过滤器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 怎样在controller中使用filter

在controller中使用filter有两种方式:

1.直接把要使用的过滤器filter注入到controller中,比如有个currencyFilter:

app.controller('test',function($scope,currencyFilter){

$scope.num= currencyFilter(123534);

}

2.可以通过注入$filter过滤器到controller中:

app.controller('test',function($scope,$filter){

$scope.num=$filter('currency')(123534);

$scope.date =$filter('date')(newDate());

}

『拾』 angularjs如何将时间戳转换成格式化时间求代码啊

本地化日期格式化:
({{today|date:'medium'}})Nov19,20153:57:48PM
({{today|date:'short'}})11/19/153:57PM
({{today|date:'fullDate'}})Thursday,November19,2015
({{today|date:'longDate'}})November19,2015
({{today|date:'mediumDate'}})Nov19,2015
({{today|date:'shortDate'}})11/19/15
({{today|date:'mediumTime'}})3:57:48PM
({{today|date:'shortTime'}})3:57PM
年份格式化:
四位年份:({{today|date:'yyyy'}})2015
两位年份:({{today|date:'yy'}})15
一位年份:({{today|date:'y'}})2015
月份格式化:
英文月份:({{today|date:'MMMM'}})November
英文月份简写:({{today|date:'MMM'}})Nov
两位数字月份:({{today|date:'MM'}})11
一年中的第几个月份:({{today|date:'M'}})11
日期格式化:
数字日期:({{today|date:'dd'}})19
一个月中的第几天:({{today|date:'d'}})19
英文星期:({{today|date:'EEEE'}})Thursday
英文星期简写:({{today|date:'EEE'}})Thu
小时格式化:
24小时制数字小时:({{today|date:'HH'}})15
一天中的第几个小时:({{today|date:'H'}})15
12小时制数字小时:({{today|date:'hh'}})03
上午或下午的第几个小时:({{today|date:'h'}})3
分钟格式化:
数字分钟数:({{today|date:'mm'}})57
一个小时中的第几分钟:({{today|date:'m'}})57
秒数格式化:
数字秒数:({{today|date:'ss'}})48
一分钟中内的第几秒:({{today|date:'s'}})48
毫秒数格式化:
毫秒数:({{today|date:'sss'}})541
字符格式化:
上下午标识:({{today|date:'a'}})PM
四位时区标识:({{today|date:'Z'}})+0800
自定义日期格式化:
年月日:({{today|date:'yyyy-MM-dd'}})2015-11-19
时分秒:({{today|date:'HH:mm:ss.sss'}})15:57:48.541

阅读全文

与angularjs时间戳过滤器相关的资料

热点内容
edi的工作流程图片 浏览:158
蒸馏化学图 浏览:850
反渗透设备加药剂量怎么换算 浏览:937
同时蒸馏萃取 浏览:18
戴森净化器没有更换滤芯怎么重置 浏览:820
酷路泽内置汽油滤芯怎么更换 浏览:142
ps空气净化器光效怎么做 浏览:633
污水设备调节池里面有什么设备 浏览:653
城市污水沟处理怎么样 浏览:965
圆底烧瓶平底烧瓶蒸馏烧瓶的区别 浏览:458
特种涂料和树脂支持政策 浏览:505
PVDF超滤膜滤芯是什么 浏览:55
反渗透膜多大的省水 浏览:44
小区污水排污流量计算 浏览:764
石油废水成分 浏览:977
热水器维里的水垢怎么出里 浏览:404
山西新农村污水处理设备多少钱 浏览:431
废水回收泵 浏览:412
eva树脂专用附着力促进剂 浏览:962
净水器换完滤芯废水管一直漏水怎么回事 浏览:859