通常我们服务器端的时间使用UTC格式,避免服务器的时区对最终的时间产生影响。而客户端需要根据具体的时区显示local time,本文将介绍如何将服务器的UTC time(基于asp.net web api实现的web service)与客户端的local time(基于ionic实现的hybrid app)进行相互转换。

1. Convert UTC time to local time

应用场景:通常在请求结束之后,把服务器的数据转换成本地数据。

在service中定义filter,需要传入连个参数:utc格式的时间字符串和转换格式。

.filter('utcToLocal', function utcToLocal($filter) {
return function (utcDateString, format) {
if (!utcDateString) {
return;
} if (utcDateString.indexOf('Z') === -1 && utcDateString.indexOf('+') === -1) {
utcDateString += 'Z';
} return $filter('date')(utcDateString, format);
};
})

在页面中使用filter:

<p>{{item.triggeredTimeString|utcToLocal:"yyyy-MM-dd HH:mm:ss"}}</p>

如何在directives中使用呢?需要重新定义utcToLocal函数,调用如下。注意:需要在根指令处声明$filter。

var utcToLocal = function(utcDateString) {
if (!utcDateString) {
return;
} if (utcDateString.indexOf('Z') === -1 && utcDateString.indexOf('+') === -1) {
utcDateString += 'Z';
} return $filter('date')(utcDateString, "yyyy-MM-dd HH:mm:ss");
} $filter('date')(utcDateString, "yyyy-MM-dd HH:mm:ss");

2. Convert local time to UTC time

应用场景:通常调用服务发送数据时使用。

2.1 定义一个函数,使用UTC Date的构造函数来生成UTC时间。

var toUTCDate = function(date){
var _utc = new Date(date.getUTCFullYear(), date.getUTCMonth(), date.getUTCDate(), date.getUTCHours(), date.getUTCMinutes(), date.getUTCSeconds());
return _utc;
}; var localTime = new Date();
var utcTime = toUTCDate(localTime);
$log.info(localTime);
$log.info(utcTime);

2.2 直接使用库函数toUTCString:

var localTime = new Date();
var utc = localTime.toUTCString();

2.3 使用Moment.js

var localTime = new Date();
moment.utc(localTime);

2.4 扩展库函数,封装addDays和convertToUtcString:

Date.prototype.convertToUtcString = function() {
return (this.getUTCMonth()+1) + "-" + this.getUTCDate() + "-" + this.getUTCFullYear() + " " + this.getUTCHours() + ":" + this.getUTCMinutes() + ":" + this.getUTCSeconds();
} Date.prototype.convertToLocalString = function() {
return (this.getMonth()+1) + "-" + this.getDate() + "-" + this.getFullYear() + " " + this.getHours() + ":" + this.getMinutes() + ":" + this.getSeconds();
} Date.prototype.getYtdUtcString = function() {
return "1-1-" + this.getFullYear() + " 12:00:00";
} Date.prototype.addDays = function(num) {
var value = this.valueOf();
value += 86400000 * num;
return new Date(value);
}

参考资料:

http://stackoverflow.com/questions/31778624/converting-local-time-into-utc-time-in-angularjs

https://github.com/urish/angular-moment

http://stackoverflow.com/questions/31785364/converting-date-from-local-time-zone-to-utc-and-then-to-local

最新文章

  1. SQLServer控制用户访问权限表
  2. UrlRewriter实现.NET的URL重写
  3. &lt;转&gt;linux crontab 定时任务
  4. VB.NET vs. C#
  5. 常用的HTTP协议
  6. php部分(查看文件、建立站点、语法变量、变量的几个方法、“全局局部变量的调用”、static、函数参数的作用域);
  7. Qt之启动外部程序
  8. strlen的C/C+++实现
  9. C_数据结构_链表的链式实现
  10. VB6-图像分割利器 Microsoft Picture Clip控件
  11. 纯CSS实现delay连续动画
  12. 学习DTD和Schema的几个例子
  13. 继承Application实现Android数据共享
  14. moment.js
  15. Kafka 生产者和消费者入门代码基础
  16. java重写equals方法需要注意的几点
  17. [转]group by 后使用 rollup 子句总结
  18. git本地仓库关联多个remote,怎么用本地一个分支向不同remote不同分支推送代码
  19. Sorl搜索技术
  20. SVN提交强制输入日志信息

热门文章

  1. Visual Studio 2013 新增功能:“Browser Link”
  2. 「POJ 2699」The Maximum Number of Strong Kings
  3. 《C#多线程编程实战》2.10 SpinWait
  4. 【转】检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件失败,原因是出现以下错误: 80070005 拒绝访问
  5. 【guava】对象处理
  6. Mysql数据库申请
  7. CentOS7.3托管磁盘虚拟机扩容数据磁盘
  8. 树状数组【洛谷P3586】 [POI2015]LOG
  9. 【离散数学】 SDUT OJ 集合的包含
  10. 微信小程序获取用户手机号,服务器解码demo