最初對(duì)做兼容性的認(rèn)知只停留在UI層面,但其實(shí)UI層面都還好,因?yàn)楫吘鼓憧梢灾苯涌吹靡姮F(xiàn)象,更為重要的是在JavaScript層面,因?yàn)檫@個(gè)部分涉及到功能性,前者最多是體驗(yàn)性的問題。下面扯一下這幾天遇到的IE8相關(guān)的兼容性問題。
1.所有$.ajax失效
剛開始看到的現(xiàn)象是IE8/9頁面切到了留言頁面,沒有進(jìn)入正常流程。打開fiddler都沒抓到請(qǐng)求,奇怪了,打出$.ajax error方法中的返回值。xhr.status的值都是0,原來請(qǐng)求沒有發(fā)出去。心想:怎么沒有發(fā)出去呢,難道是跨域問題,不對(duì)啊,服務(wù)端已經(jīng)允許跨域了。后來一查(IE8/9下的跨域資源請(qǐng)求),原來請(qǐng)求被IE8/9阻止了,所以服務(wù)端允許跨域了也沒有用。當(dāng)時(shí)網(wǎng)上有兩種辦法,1個(gè)是設(shè)置瀏覽器,允許通過域訪問數(shù)據(jù)源。2個(gè)是加入一個(gè)js插件,也就是讓IE8/9/10走IE自己支持的XDomainRequest發(fā)送請(qǐng)求。第一個(gè)方法只能玩玩,不可能讓用戶去操作套路那么深的步驟。第二個(gè)方法github上有兩套js。
https://github.com/MoonScript/jQuery-ajaxTransport-XDomainRequest
https://github.com/jaubourg/ajaxHooks/blob/master/src/xdr.js
引用后都不用改代碼,剛開始還有點(diǎn)小激動(dòng)。
<!--[if (IE 8)|(IE 9)]><script src="Js/jQuery.XDOmainRequest.js"></script><![endif]-->
加上去一看,請(qǐng)求發(fā)過去了,界面進(jìn)入了正常流程。but,又發(fā)現(xiàn)返回的值不對(duì),說與服務(wù)端,服務(wù)端說你的值沒傳過來,怎么可能,代碼都沒動(dòng),原來這個(gè)XDomainRequest是參數(shù)走的header,先天性缺少contentType,沒有參數(shù)的請(qǐng)求返回是正確的,有參數(shù)的后臺(tái)就沒有讀到。又尋思著難道要后臺(tái)改代碼,支持一下這種方式?我遲疑了。然后就到群里和隊(duì)友們討論下。大家給出