亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

解決js ajax同步請(qǐng)求造成瀏覽器假死的問(wèn)題

 更新時(shí)間:2018年01月18日 15:17:52   作者:來(lái)自潘大大  
下面小編就為大家分享一篇解決js ajax同步請(qǐng)求造成瀏覽器假死的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

一、問(wèn)題的起因

今天做一個(gè)需求遇到了這么個(gè)情況,就是用戶個(gè)人中心有個(gè)功能,點(diǎn)擊按鈕,可以刷新用戶當(dāng)前的積分,這個(gè)肯定需要使用到ajax的同步請(qǐng)求了,當(dāng)時(shí)喀喀喀三下五除二寫玩了,大概代碼如下:

/**
  * 異步當(dāng)前用戶積分 by zgw 20161216
  * @return {[type]} [description]
 */
 function flushIntegralSum() {
     //點(diǎn)擊按鈕刷新前修改按鈕的文案,已經(jīng)去掉點(diǎn)擊事情,防止多次點(diǎn)擊
  $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" id="flushbutton">正在刷新</a>');
  $.ajax({
   url:'URL',
   type:'post',
   async:false,
   // data:{},
   success:function(json){
    json = eval('('+json+')');
    if(json.url){window.location.href=json.url;return;}
    $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="flushFreeSum();" id="flushbutton">刷新積分</a>');
    if(json.code!=1){
     alert(json.msg);
    }else{
     $("#free_sum").html(json.free_sum);
    }
    return;
   }
  });
 }

本以為這么簡(jiǎn)單的功能喀喀喀隨便寫寫就沒(méi)事了,在運(yùn)行的時(shí)候出現(xiàn)了問(wèn)題,當(dāng)用戶點(diǎn)擊刷新積分按鈕時(shí),文案沒(méi)有修改為"正在刷新",但是ajax請(qǐng)求發(fā)送了,于是我查看網(wǎng)頁(yè)代碼,發(fā)現(xiàn)js其實(shí)把文案和html元素綁定的onclick事件去掉了,在請(qǐng)求成功后有變回原來(lái)的了,但是頁(yè)面上邊文案沒(méi)有改變,當(dāng)時(shí)很奇怪,不知道為什么html代碼里邊改變了,頁(yè)面卻沒(méi)有變點(diǎn)變化

二、了解問(wèn)題原因

問(wèn)題的根源:當(dāng)時(shí)我進(jìn)行了排查,最后發(fā)現(xiàn)是 "async:false" 的問(wèn)題,換成異步的就沒(méi)有問(wèn)題了,那為什么同步請(qǐng)求會(huì)產(chǎn)生代碼失效的問(wèn)題呢?

原因:瀏覽器的渲染(UI)線程和js線程是互斥的,在執(zhí)行js耗時(shí)操作時(shí),頁(yè)面渲染會(huì)被阻塞掉。當(dāng)我們執(zhí)行異步ajax的時(shí)候沒(méi)有問(wèn)題,但當(dāng)設(shè)置為同步請(qǐng)求時(shí),其他的動(dòng)作(ajax函數(shù)后面的代碼,還有渲染線程)都會(huì)停止下來(lái)。即使我的DOM操作語(yǔ)句是在發(fā)起請(qǐng)求的前一句,這個(gè)同步請(qǐng)求也會(huì)“迅速”將UI線程阻塞,不給它執(zhí)行的時(shí)間。這就是代碼失效的原因。

三、解決問(wèn)題

1.我當(dāng)時(shí)使用了 setTimeout 來(lái)解決,把a(bǔ)jax代碼放在sestTimeout中,讓瀏覽器重啟一個(gè)線程來(lái)操作,這樣就解決問(wèn)題了,代碼如下:

function flushIntegralSum() {
     //點(diǎn)擊按鈕刷新前修改按鈕的文案,已經(jīng)去掉點(diǎn)擊事情,防止多次點(diǎn)擊
  $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" id="flushbutton">正在刷新</a>');
  setTimeout(function(){
   $.ajax({
    url:'URL',
    type:'post',
    async:false,
    // data:{},
    success:function(json){
     json = eval('('+json+')');
     if(json.url){window.location.href=json.url;return;}
     $("#flushbutton").replaceWith('<a style="color:#3fb0ff;font-size:14px;" href="javascript:void(0);" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="flushFreeSum();" id="flushbutton">刷新積分</a>');
     if(json.code!=1){
      alert(json.msg);
     }else{
      $("#free_sum").html(json.free_sum);
     }
     return;
    }
   });
  },0) 
 }

setTimeout的第二個(gè)參數(shù)設(shè)為0,瀏覽器會(huì)在一個(gè)已設(shè)的最小時(shí)間后執(zhí)行

到這里問(wèn)題就解決了,但是你可以試試當(dāng)你點(diǎn)擊按鈕的時(shí)候如果需要彈出一個(gè)gif圖片,并且圖片一直在旋轉(zhuǎn),提示更新中,你會(huì)發(fā)現(xiàn)圖片雖然會(huì)顯示,但是圖片卻是不動(dòng)的,那是因?yàn)殡m然同步請(qǐng)求延遲執(zhí)行了,但是它執(zhí)行期間還是會(huì)把UI線程給阻塞。這個(gè)阻塞相當(dāng)牛逼,連gif圖片都不動(dòng)了,看起來(lái)像一張靜態(tài)圖片一樣。結(jié)論很明顯,setTimeout治標(biāo)不治本,相當(dāng)于把同步請(qǐng)求“稍稍”異步了一下,接下來(lái)還是會(huì)進(jìn)入同步的噩夢(mèng),阻塞線程,這種方法只適合發(fā)請(qǐng)求之前操作簡(jiǎn)單的時(shí)間短的情況

2.使用 Deferred 來(lái)解決

以上這篇解決js ajax同步請(qǐng)求造成瀏覽器假死的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Javascript原生ajax請(qǐng)求代碼實(shí)例

    Javascript原生ajax請(qǐng)求代碼實(shí)例

    這篇文章主要介紹了Javascript原生ajax請(qǐng)求代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • JavaScript Date對(duì)象使用總結(jié)

    JavaScript Date對(duì)象使用總結(jié)

    js 日期對(duì)象的一些方法總結(jié)
    2009-05-05
  • 帶你使用webpack快速構(gòu)建web項(xiàng)目的方法

    帶你使用webpack快速構(gòu)建web項(xiàng)目的方法

    這篇文章主要介紹了帶你使用webpack快速構(gòu)建web項(xiàng)目的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • 基于iscroll.js實(shí)現(xiàn)下拉刷新和上拉加載效果

    基于iscroll.js實(shí)現(xiàn)下拉刷新和上拉加載效果

    這篇文章主要為大家詳細(xì)介紹了基于iscroll.js實(shí)現(xiàn)下拉刷新和上拉加載效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • 非jQuery實(shí)現(xiàn)照片散落桌子上,單擊放大的LightBox效果

    非jQuery實(shí)現(xiàn)照片散落桌子上,單擊放大的LightBox效果

    本文給大家介紹一款js實(shí)現(xiàn)的照片散落桌子上點(diǎn)擊放大圖片的LightBox效果,非常的炫酷,而且是非jQuery實(shí)現(xiàn)的,有需要的小伙伴可以參考下
    2014-11-11
  • 原生js實(shí)現(xiàn)密碼強(qiáng)度驗(yàn)證功能

    原生js實(shí)現(xiàn)密碼強(qiáng)度驗(yàn)證功能

    這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)密碼強(qiáng)度驗(yàn)證功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • 解決typescript?提示?Object?is?possibly'null'的N種方案

    解決typescript?提示?Object?is?possibly'null'的N種方案

    這篇文章主要介紹了typescript?提示?Object?is?possibly?‘null‘?的N種解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-03-03
  • JS刷新框架外頁(yè)面七種實(shí)現(xiàn)代碼

    JS刷新框架外頁(yè)面七種實(shí)現(xiàn)代碼

    JS刷新框架想必大家們都有所了解,如何是刷新框架外頁(yè)面想必大家有所陌生啦,沒(méi)關(guān)系本文的出現(xiàn)將解決大家的燃眉之急,感興趣的你可不要錯(cuò)過(guò)了哈
    2013-02-02
  • layUI的驗(yàn)證碼功能及校驗(yàn)實(shí)例

    layUI的驗(yàn)證碼功能及校驗(yàn)實(shí)例

    今天小編就為大家分享一篇layUI的驗(yàn)證碼功能及校驗(yàn)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • 解決微信內(nèi)置瀏覽器返回上一頁(yè)強(qiáng)制刷新問(wèn)題方法

    解決微信內(nèi)置瀏覽器返回上一頁(yè)強(qiáng)制刷新問(wèn)題方法

    微信內(nèi)置瀏覽器在返回上一頁(yè)面,且上一頁(yè)面包含AJAX代碼時(shí),頁(yè)面就會(huì)被強(qiáng)制刷新,極度影響用戶體驗(yàn)。而我們想要的效果是:返回上一頁(yè)面時(shí),頁(yè)面還停留在原來(lái)的狀態(tài),AJAX獲取到的數(shù)據(jù)還在,滾動(dòng)條也在原來(lái)的位置。下面跟著小編一起來(lái)看下吧
    2017-02-02

最新評(píng)論