关于使用ajax给全局变量赋值失败的问题
比如
var num = 5;$.ajax({url: "../TongJiBaoBiao/ZhengQueLv", success: function (res) {json = JSON.parse(res);alert("json[0].Column:" + json[0].Column1);}});num = parseInt(json[0].Column1);以上代碼alert能夠獲取到內(nèi)容,但是 num = parseInt(json[0].Column1)中num的賦值是失敗的。
原因如下:
ajax默認(rèn)為異步請(qǐng)求,也就是
async在不寫的情況下默認(rèn)為async: true;
什么是異步請(qǐng)求呢?
就是ajax里邊的回調(diào)函數(shù)function(),是在后端數(shù)據(jù)返回后才執(zhí)行,原script代碼在執(zhí)行g(shù)et或post請(qǐng)求后就繼續(xù)執(zhí)行往下的代碼了,等到后端數(shù)據(jù)發(fā)送過(guò)來(lái)后,才回過(guò)頭來(lái)執(zhí)行function()函數(shù),于是function()后給num的賦值操作num = parseInt(json[0].Column1)會(huì)先被執(zhí)行,然后再執(zhí)行function()函數(shù),所以,但是num的賦值跟function()的返回值有關(guān),所以導(dǎo)致失敗。這也是function()函數(shù)被稱為回調(diào)函數(shù)的原因。也是被稱為異步的原因。
解決辦法
把異步請(qǐng)求去掉,改成同步請(qǐng)求:
總結(jié)
以上是生活随笔為你收集整理的关于使用ajax给全局变量赋值失败的问题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 加密小原理1
- 下一篇: 关于文件格式和编码方式,乱码产生的原因?