最初對做兼容性的認知只停留在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都是不同的域名.