[英]How to convert this date into a different format
這是我的Angular應用
var filterData = angular.module('myApp',[]).controller('CallWebApi', function($scope, $http) {
// Local version of the data
$http.get('./events.js').
success(function (data) {
$scope.data = data.result.items;
console.log('success ' + data)
})
.error(function(data) {
console.log('failure ' + data)
});
});
filterData.filter('removeSpacesThenLowercase', function () {
return function (text) {
var str = text.replace(/\s+/g, '-');
return str.toLowerCase();
};
})
日期在我的數據中看起來像這樣:
"{B588A80F-A8C0-4A97-A35A-07D81ED53E9B}": {
"Name": "Expiration Date",
"Type": "Date",
"Value": "20150827T000000"
},
這是我的HTML:
<table>
<tr>
<th>Name</th>
<th>Location</th>
<th>Date</th>
</tr>
<tr ng-repeat="item in data">
<td><a href="{{ item.Name | removeSpacesThenLowercase }}">{{ item.Fields["{BB2389F3-555B-4FC6-B106-C0A23A55A15F}"].Value }}</a></td>
<td>{{ item.Fields["{123A77C7-07D5-4CAA-85E0-8F9B9CEE110C}"].Value }}</td>
<td>{{ item.Fields["{B588A80F-A8C0-4A97-A35A-07D81ED53E9B}"].Value }}</td>
</tr>
</table>
如何轉換此日期:
20150827T000000
轉換成這種格式:
2015年8月27日?
這應該工作:
var d = '20150827T000000';
console.log(d.substr(4,2) + '/' + d.substr(6,2) + '/' + d.substr(0,4));
// will give you '08/27/2015'
我創建了一個關於如何將其集成到angular中的演示: http : //plnkr.co/edit/KheLKhLHgGYoF0R5CZgf?p=preview
您可以創建一個過濾器:
myModule.filter('formatData', function () {
return function (d) {
return d.substr(4,2) + '/' + d.substr(6,2) + '/' + d.substr(0,4);
};
})
然后在您的視圖中使用它:
{{test["{B588A80F-A8C0-4A97-A35A-07D81ED53E9B}"].Value|formatData}}
以及用於格式化數據的fork: http : //plnkr.co/edit/EReUj4GkhGF36SS6RaX4?p=preview
您可以在內置的Date
對象上嘗試使用DateX和eXtension(ps作者)
例:
var date = new DateX( );
var formatted = date.format('Y-m-d H:i:s');
var parsed = DateX.parse(formatted, 'Y-m-d H:i:s');
console.log(formatted);
console.log(parsed.format('Y-m-d H:i:s'));
以您的示例為例,可以將其解析(並同時驗證)為實際日期
var date = DateX.parse("20150827T000000", 'YmdHis');
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.