从JS原生Date类型浅谈web开发兼容性

最近在魔改一个校园信息系统微信小程序,在计算当前教学周,需要获取特定日期的周数。大家知道,在java世界里面调用 **Calendar.WEEK_OF_YEAR **就可以得到指定日期的周数了,可是小程序前端开发只能使用Javascript,而在js中没有类似这样的方法直接获取。

最容易的方法就是每次都向服务器获取教学周,可这太重量级,为了一个变量发送一次请求,每次打开小程序都要请求一次数据,再渲染,非常的耗时。于是上网找到一个function关于js 计算指定日期的周数,搬运工就这样以为成了,可发现原作者计算方法有误,传入的date对象如果是当天的上午为 N 周,如果传入的值是同一天的下午则为 N+1 周,这导致课表上午显示正常,下午显示就不正常了,以为是我计算错了,没有把开始的那周计算进去,细细排查发现是网上搬过来的function在取模的时候有误。于是传入的对象不再是 **new Date() 就完事,而是变成new Date(‘'2017-03-01'’) 这样,得到的data对象按道理应是这样:Wed Mar 01 2017 08:00:00 GMT+0800 (China Standard Time) ,的确在安卓端是这样的,小程序运行正常,教学周显示正常,然而用iphone测试,教学周一直显示 null ,期间我把所有的传入的值都使用了parseInt(),问题照旧,获取不到周数,就无法正常显示当天课程,到这时候不管你们崩溃没,反正我是已经想死了…….这时候发现问题大了,赶紧把小程序下线,要不别人以为当天没课。于是借了土豪的手机来开发,临近崩溃边缘,吐槽微信开发工具,模拟出来的iphone和真正的iphone完全是两码事,很多特征不一样,css布局都差很多,还有这个教学周问题,在模拟器上玩得好好的。接着调试代码一直跟踪到new data()对象本身,竟然发现在iphone new Date(‘'2017-03-01'’)会得到 Invalid Date ,我的天,什么回事,谜一样的,谷歌” Javascipt Invalid Date”查到 new Date()在解析一个具体的时间的时候,对参数有较严格的格式要求,格式不正确的时候会直接返回Invalid Date 。那么new Date()能接受的参数格式到底是什么标准呢?显然到了这里可以知道,ios和android 执行的标准不一样,new Date()传入字符串格式需要满足 RFC2822 标准或者ISO 8601标准,我用的是ISO 8601标准日期字符串(YYYY-MM-DDThh:mm:ss),而RFC2822 标准日期字符串长这样的:YYYY/MM/DD HH:MM:SS ± timezon(时区用4位数字表示),按道理有ISO应该好很多,毕竟是国际标准化组织的东西,然而事实并非如此, RFC2822兼容性才是最好的,比如IE8、Safari、iOS均不支持ISO 8601。IE这种东西你可能会不屑,不过iOS也有这个坑,不得不去提防,所以建议大家还是用RFC2822。回到小程序,在new Date()传入参数的标准改为RFC2822,兼容性问题解决,终于计算出准确的教学周。之后为了更优雅的完成教学周的计算,通过改写Date实例,定义schoolweek获取器,它会返回当前到指定时间的周数间隔。简单地访问该属性就会调用事先定义好的函数,无需显示调用。来源不明的函数还是要多加留意,如果是引入不明依赖,水更深,特别是在开发重要的系统,更需要严格审核每个依赖包。

sp170314_200735.png

说到这里兼容性问题已经非常凸显,应了那句话,一进前端深似海~~一直以为只有IE是浏览器一大奇葩,现在多了一朵,傲娇的iOS系统居然也不支持ISO 8601日期字符串,其实在web开发过程中,兼容性多是浏览器执行标准的问题。IE逐渐退出舞台,微软都放弃了,我想应该无需什么保留了,但面对iOS就不能那么任性了,顺便说一下,一开头说的 Calendar.WEEK_OF_YEAR ** 是Java 的 SimpleDateFormat **jar,建议不要使用,推荐使用Java8 Time,SimpleDateFormat也是挺坑的,简单点就是 SimpleDateFormat 时间对象序列化成字符串之后,反序列化成和原对象表达不是同一个时间的时间对象了,如果是维护遗留项目没法改的话小心点咯,新项目建议尽量不要使用SimpleDateFormat jar。

在前端两个月玩得挺开心的,作为Java的忠粉,准备做完这个轮子后弃小程序坑了~~用javascript这种弱类型语言太久,回到Java的世界,感觉能创造一个宇宙。

希望对看到这篇文章的人有点帮助。

预告: 微信小程序如何埋点做用户画像

转载请注明出自:后端之巅

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容