向Asp.net Ajax 传入DateTime类型后时间会变为零时区的时间,换句话说也就是比中国的时间少了8个小时。
例如:
自定义类型MyOrder
关于在Asp.net Ajax里面使用自定义类型请参考
使用ASP.NET AJAX异步调用Web Service和页面中的类方法(6):服务器端和客户端数据类型的自动转换:复杂类型
C#
public class MyOrder()
{
public MyOrder()
{
}
private DateTime _OrderDateTime;
public DateTime OrderDateTime
{
get
{
return _OrderDateTime;
}
set
{
_OrderDateTime=value;
}
}
…………其他略
}
JS
function()
{
var order=new MyOrder();
MyOrder.OrderDateTime=new Date();
…………其他略
}
然后在WebService里面查看,传入后OrderDateTime少了8个小时。
如果直接以DateTime参数传入Sql写入数据库就变回了正常的时间。
最后发现是时区的问题。
解决方案是调用DateTime的ToLocalTime()方法。如果本地计算机时区设置正确,那么返回回来的时区也是正确的。
也查询过一些资料,也可以直接加上8个小时,不过传入的时间是带时区信息的。用ToLocalTime()好像更好些。另外我试着设置web.config将<globalization culture="zh-CN" enableClientBasedCulture="false"/>但并不起作用。
关于ToLocalTime
将当前 DateTime 对象的值转换为本地时间。
命名空间:System
程序集:mscorlib(在 mscorlib.dll 中)
语法
返回值
一个
DateTime 对象,其
Kind 属性为
Local,并且其值为等效于当前
DateTime 对象的值的本地时间;如果经转换的值过大以至于不能由
DateTime 对象表示,则为
MaxValue,或者,如果经转换的值过小以至于不能表示为
DateTime 对象,则为
MinValue。
备注
posted @ 2007-08-20 17:23
提示符 阅读(1718)
评论(3) 编辑 收藏 所属分类:
.Net 2.0 、
C# 、
ASP.Net 、
Javascript