最初對做兼容性的認知只停留在UI層面,但其實UI層面都還好,因為畢竟你可以直接看得見現(xiàn)象,更為重要的是在JavaScript層面,因為這個部分涉及到功能性,前者最多是體驗性的問題。下面扯一下這幾天遇到的IE8相關(guān)的兼容性問題。
1.所有$.ajax失效
剛開始看到的現(xiàn)象是IE8/9頁面切到了留言頁面,沒有進入正常流程。打開fiddler都沒抓到請求,奇怪了,打出$.ajax error方法中的返回值。xhr.status的值都是0,原來請求沒有發(fā)出去。心想:怎么沒有發(fā)出去呢,難道是跨域問題,不對啊,服務(wù)端已經(jīng)允許跨域了。后來一查(IE8/9下的跨域資源請求),原來請求被IE8/9阻止了,所以服務(wù)端允許跨域了也沒有用。當時網(wǎng)上有兩種辦法,1個是設(shè)置瀏覽器,允許通過域訪問數(shù)據(jù)源。2個是加入一個js插件,也就是讓IE8/9/10走IE自己支持的XDomainRequest發(fā)送請求。第一個方法只能玩玩,不可能讓用戶去操作套路那么深的步驟。第二個方法github上有兩套js。
<!--[if (IE 8)|(IE 9)]><script src="Js/jQuery.XDOmainRequest.js"></script><![endif]-->
加上去一看,請求發(fā)過去了,界面進入了正常流程。but,又發(fā)現(xiàn)返回的值不對,說與服務(wù)端,服務(wù)端說你的值沒傳過來,怎么可能,代碼都沒動,原來這個XDomainRequest是參數(shù)走的header,先天性缺少contentType,沒有參數(shù)的請求返回是正確的,有參數(shù)的后臺就沒有讀到。又尋思著難道要后臺改代碼,支持一下這種方式?我遲疑了。然后就到群里和隊友們討論下。大家給出的方案就是,用Nginx配置個代理就好了。啊,一時激動的有點難以言表。繞了一大圈,啥都不用改,服務(wù)器上配置下就好了。因為,既然是跨域問題,最根本的方法就是讓它不用跨域了。這種前后端分離的架構(gòu),網(wǎng)站(html)和api都是不同的域名.
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26