ajax回調(diào)函數(shù)參數(shù)傳遞正確方法
function ClassX(name) {
this.name = name;
ClassX.prototype.show = function (param) {
alert(this.name + " " + param);
};
}
var o = new ClassX("name");
o.show("param");//name param
但是,上面是雖然是直接在函數(shù)簽名中定義了參考,如果不是自己調(diào)用o.show('param')時(shí),而是通過(guò)其他函數(shù)回調(diào)傳入時(shí),就不一定好使了,因?yàn)閯e人在調(diào)用此方法時(shí)不一定給你傳入此參,比如在使用ajax時(shí)
request.onreadystatechange=function(param){...}
或
request.onreadystatechange=callBack;function callBack(param){...}
時(shí)就不好使了,因?yàn)榇藭r(shí)ajax根本就沒(méi)有給你傳遞param參數(shù),正確做法形如:
//request.onreadystatechange = orgEval;//錯(cuò)誤作法
//request.onreadystatechange = function (request, pOrgName) {//錯(cuò)誤作法
// orgEval(request, pOrgName);
//};
//...
request.onreadystatechange = function () {//正確作法
orgEval(request, pOrgName);//在匿名函數(shù)內(nèi)調(diào)用回調(diào)實(shí)現(xiàn),并直接傳入?yún)?shù),這里用到了JavaScript的閉包性質(zhì)
};
//...
function orgEval(req, orgName){
//...
}
這樣通過(guò)在匿名函數(shù)內(nèi)調(diào)用回調(diào)實(shí)現(xiàn)函數(shù),并且直接傳入?yún)?shù)即可。
ajax傳遞參數(shù)給onreadystatechange的回調(diào)函數(shù)
這幾天開始學(xué)習(xí)ajax,其中自己做試驗(yàn)頁(yè)面時(shí)有了傳參數(shù)給XMLHttpRequest.onreadystatechange的回調(diào)函數(shù)這個(gè)需求。如是baidu了下,發(fā)現(xiàn)說(shuō)到這個(gè)的人不少啊。搜來(lái)的辦法大概是這樣:
xmlHttp.onreadystatechange=function(){callback(a,b);};
其中就傳遞了a和b兩個(gè)參數(shù)。
后來(lái)我又自己發(fā)現(xiàn)了個(gè)方法,方法知道的人肯定很多,不過(guò)我在baidu上沒(méi)搜到,這里就寫出來(lái),推廣下咯。
xmlHttp.a=a;
xmlHttp.b=b;
xmlHttp.onreadystatechange=callback;
.
.
function callback()
{
if(this.readyState==4)
{
a=this.a;
b=this.b;
.
}
}
也就是給xmlHttp對(duì)象增加兩個(gè)屬性,在回調(diào)函數(shù)中直接用this調(diào)用那兩個(gè)屬性。
另外說(shuō)點(diǎn)自己的小經(jīng)驗(yàn),xmlHttp最好要寫成全局變量,我一開始發(fā)現(xiàn)總有些請(qǐng)求沒(méi)達(dá)到目的。后來(lái)才發(fā)現(xiàn)是把xmlHttp寫在了一個(gè)函數(shù)里面,當(dāng)那個(gè)函數(shù)運(yùn)行完了,xmlHttp生命周期也結(jié)束了。這樣有些請(qǐng)求在生命周期結(jié)束之前就實(shí)現(xiàn)了,而有些請(qǐng)求就沒(méi)了。
- jQuery Ajax Post 回調(diào)函數(shù)不執(zhí)行問(wèn)題的解決方法
- Javascript基于AJAX回調(diào)函數(shù)傳遞參數(shù)實(shí)例分析
- ajax回調(diào)函數(shù)中使用$(this)取不到對(duì)象的解決方法
- ajax請(qǐng)求返回的數(shù)據(jù)看不到回調(diào)函數(shù)沒(méi)有執(zhí)行也沒(méi)報(bào)錯(cuò)
- 解決ajax回調(diào)函數(shù)返回的字符串亂碼問(wèn)題
- ajax異步回調(diào)函數(shù)中給外部變量賦值的問(wèn)題探討
- ajax JSONP請(qǐng)求處理回調(diào)函數(shù)jsonpCallback區(qū)分大小寫
- jQuery Tips 為AJAX回調(diào)函數(shù)傳遞額外參數(shù)的方法
- JQuery中使用Ajax賦值給全局變量失敗異常的解決方法
- ajax給全局變量賦值問(wèn)題解決示例
- JQuery中使用Ajax賦值給全局變量異常的解決方法
- jquery ajax修改全局變量示例代碼
- Ajax獲取回調(diào)函數(shù)無(wú)法賦值給全局變量的問(wèn)題
相關(guān)文章
jquery中AJAX請(qǐng)求 $.post方法的使用
使用jQuery的$.post方法可以以POST形式向服務(wù)器發(fā)起AJAX請(qǐng)求.本篇文章主要給大家講解jquery中AJAX請(qǐng)求 $.post方法的使用,需要的朋友可以參考下2015-10-10ajax實(shí)現(xiàn)簡(jiǎn)單實(shí)時(shí)驗(yàn)證功能
這篇文章主要介紹了ajax實(shí)現(xiàn)簡(jiǎn)單實(shí)時(shí)驗(yàn)證功能,需要的朋友可以參考下2017-12-12Ajax修改數(shù)據(jù)即時(shí)顯示篇實(shí)現(xiàn)代碼
上一篇我們講了如何使用ajax向數(shù)據(jù)庫(kù)添加數(shù)據(jù),今天我們要大家學(xué)習(xí)的課程是:使用ajax修改數(shù)據(jù)庫(kù)數(shù)據(jù),并在客戶網(wǎng)頁(yè)立即顯示新的內(nèi)容.當(dāng)然在修改的過(guò)程中同樣不會(huì)有刷新網(wǎng)頁(yè)的情況發(fā)生!2010-10-10Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)(三)
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)城市二級(jí)聯(lián)動(dòng)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02