Ajax,UTF-8還是GB2312 eval 還是execScript
第一題:
xmlhttp 的 responseText 默認(rèn)總是utf-8的編碼,前段時(shí)間為了以最小成本解決這個(gè)問題,索性整個(gè)項(xiàng)目用utf-8編碼。網(wǎng)上解決的方法不多,而且都是比較亂七八糟的,不喜歡。又不能以后所有都用utf-8。
第二題:
xmlhttp 載入頁的javascript腳本,不能執(zhí)行。事件的驅(qū)動卻仍然可用,前段時(shí)間為了回避這東西,干脆把腳本全寫一起了。惡心,總這么干,每次都要載入幾百K的js文件,惡心。
那么,現(xiàn)在有時(shí)間了,最用正統(tǒng)的方式解決一下,
xmlhttp ,本來就是用來操作xml的,responseText 返回的東西,使用網(wǎng)上的二進(jìn)制硬性編碼把UTF-8改成GB2312編碼的方法自然不可靠,而且如果處理其它的編碼則無能為力。使用的 responseXML 返回的 IXMLHTTPRequest 對像,依賴xml的編碼聲明,自然不可能亂碼。沒道理不用。
<?xml version="1.0" encoding="gb2312"?>
<body>
<![CDATA[
這里將是我需要的html文本,
]]>
</body>
腳本可以這么寫一行;
returnValue = xmldom.documentElement.text;
returnValue 即是我所需要的html文本,相對硬性的以字節(jié)流去改編碼,何樂而不為呢?
第一題基本解決,管你用什么編碼,utf-8,gb2315.gbk,還是8859-1 改下文檔聲明即可。
第一個(gè)問題即然以經(jīng)用了xml,那么第二個(gè)問題也很容易解決,簡單的分析一下我們的需求,執(zhí)行一個(gè)頁面的腳本,由其是在載入的頁上,普遍是在兩個(gè)地方,載之HTML之前的聲明和載入完成時(shí)的調(diào)用。至于頁面中的使用,用DHTML的事件驅(qū)動即可,那么變更一下XML的結(jié)構(gòu)。
<?xml version="1.0" encoding="gb2312"?>
<content>
<!-- 需要在頁面載入前定義的腳本 -->
<onStart>
<![CDATA[
// 這里的腳本相當(dāng)于寫在head里;
]]>
</onStart>
<!-- HTML 內(nèi)容 -->
<body>
<![CDATA[
HtmlCode
]]>
</body>
<!-- 需要在頁面載入后定義的腳本 -->
<onEnd>
<![CDATA[
// 這里的腳本相當(dāng)于寫在 body 后的;
]]>
</onEnd>
</content>
處理腳本,試著寫這幾行;
BeginScript = xmldom.documentElement.selectSingleNode("onStart").text;
htmlCode = xmldom.documentElement.selectSingleNode("body").text;
endScript = xmldom.documentElement.selectSingleNode("onEnd").text;
IE下似乎沒問題,但是firefox下報(bào)錯,可恨的firefox 下竟然是 textContent , selectSingleNode方法也不起作用, 瀏覽器識別的方法,隨處抄一個(gè)就好了?,F(xiàn)在我只去管 IE 和 Firefox ,我機(jī)器上也只有這兩個(gè),再改下代碼;
以下的前三行,是從網(wǎng)易博客上抄下來的。有問題找網(wǎng)易好了。實(shí)在懶得自己再寫,更別提讓我上網(wǎng)找了。
var isIE=(document.all&&document.getElementById&&!window.opera)?true:false;
var isMozilla=(!document.all&&document.getElementById&&!window.opera)?true:false;
var isOpera=(window.opera)?true:false;
if(isIE){
BeginScript = xmldom.documentElement.getElementsByTagName("onStart").item(0).text;
htmlCode = xmldom.documentElement.getElementsByTagName("body").item(0).text;
endScript = xmldom.documentElement.getElementsByTagName("onEnd").item(0).text;
}else{
BeginScript = xmldom.documentElement.getElementsByTagName("onStart").item(0).textContent;
htmlCode = xmldom.documentElement.getElementsByTagName("body").item(0).textContent;
endScript = xmldom.documentElement.getElementsByTagName("onEnd").item(0).textContent;
}
完成。剩下的,就是怎么去執(zhí)行。
需要動態(tài)的執(zhí)行一段腳本,能常會到三種方法。
a) JavaScript 中 Global 對像的 eval() 方法;
b) DHTML window 中的 execScript() 方法;
c) JavaScript 中的 new Function(); 對像;
三種方法,各有優(yōu)劣,
第一種,腳本的上下文關(guān)系使用調(diào)用時(shí)的上下文,明顯的存在作用域問題,執(zhí)行后的作用域僅在調(diào)用的函數(shù)或方法體內(nèi)。惡心的問題;
第二種,本身在DHTML的頂層對像window 上執(zhí)行,不存在作用域問題,但是execScript() 方法,卻存在瀏覽器兼容問題。只是IE的專有方法。在Firefox 上即無法使用;
第三種,除了使用不便以外,必竟是用來聲明一個(gè)方法的,如只需要聲明一個(gè)變量的話,也是個(gè)很煩人的問題。
如果不存在瀏覽器兼容問題的考慮,那么使用第二種是最好的選擇。
第三種,不作考慮。
第一種,若可以解決作用域問題,則是最好的。
我想到的方法如下;
我們在網(wǎng)頁里聲明一個(gè)變量,
即 var author = "戲得散人";
或聲明一個(gè)函數(shù)。
即:
function getBlogUrl(){
return author + "的博客地址: http://shizhong8841.blog.163.com";
}
在這個(gè)時(shí)候,我們相當(dāng)于
window.author = "戲得散人";
window.getMyBlogUrl = function(){
return this.author + "的博客地址:http://shizhong8841.blog.163.com";
}
那么,我們只要稍微擴(kuò)展一下window對像即可。
window.runScript = function(str){
eval(str);
}
神奇的 this 接下來,只要以 this.a=0; 或 this.funName = function(arg0){}; 這種方式編寫腳本,并調(diào)用 runScript(str); 方法,則相當(dāng)于在頁面中定義全局的屬性和方法,即可以辟開作用域問題,達(dá)到我們的目的。
現(xiàn)在,全部問題解決,并且在 InternetElpxerer 6.0 和 Firefax 2.0 下全部通過測試。寫的代碼太亂,就不往上貼了,省的丟人,但是思想,應(yīng)該還是正確的。
更多的問題,以后再說。
相關(guān)文章
原生JS封裝_new函數(shù)實(shí)現(xiàn)new關(guān)鍵字的功能
這篇文章主要介紹了原生JS封裝_new函數(shù),實(shí)現(xiàn)new關(guān)鍵字的功能 ,代碼簡單易懂,非常不錯,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08js 動態(tài)添加元素(div、li、img等)及設(shè)置屬性的方法
下面小編就為大家?guī)硪黄猨s 動態(tài)添加元素(div、li、img等)及設(shè)置屬性的方法。小編覺得聽不錯的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-07JavaScript Ajax Json實(shí)現(xiàn)上下級下拉框聯(lián)動效果實(shí)例代碼
這篇文章主要介紹了JavaScript Ajax Json實(shí)現(xiàn)上下級下拉框聯(lián)動效果實(shí)例代碼,有需要的朋友可以參考一下2013-11-11JS實(shí)現(xiàn)在線統(tǒng)計(jì)一個(gè)頁面內(nèi)鼠標(biāo)點(diǎn)擊次數(shù)的方法
這篇文章主要介紹了JS實(shí)現(xiàn)在線統(tǒng)計(jì)一個(gè)頁面內(nèi)鼠標(biāo)點(diǎn)擊次數(shù)的方法,實(shí)例分析了javascript操作Cookie實(shí)現(xiàn)計(jì)數(shù)的技巧,需要的朋友可以參考下2015-02-02微信小程序與webview交互實(shí)現(xiàn)支付功能
這篇文章主要介紹了微信小程序與webview交互實(shí)現(xiàn)支付功能,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用小程序具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Javascript的表單與驗(yàn)證-非空驗(yàn)證
JavaScript 可用來在數(shù)據(jù)被送往服務(wù)器前對 HTML 表單中的這些輸入數(shù)據(jù)進(jìn)行驗(yàn)證。本文給大家介紹javascript的表單與驗(yàn)證-非空驗(yàn)證,對javascript表單驗(yàn)證相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧2016-03-03JS判斷鼠標(biāo)進(jìn)入容器的方向與window.open新窗口被攔截的問題
這篇文章主要給大家介紹了利用Javascript判斷鼠標(biāo)進(jìn)入容器方向的方法,以及window.open新窗口被攔截的問題分析,文中給出了詳細(xì)圖文介紹和示例代碼,相信對大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,下面來一起看看吧。2016-12-12