踩坑——js閉包造成的問題

由于這3個月工作忙,好久沒有在簡書上寫文章了吗浩,今天給大家分享一個我在項目中遇到的js閉包的坑建芙。

  • 踩坑背景
    在公司的觸屏端項目中,用的react+redux拓萌,我們的方法都是統(tǒng)一在params.js中傳遞給對應的組件岁钓。我現(xiàn)在有一個需求:列表頁滑到底部,需要重新請求接口,請求接口時需要把上一次接口返回的數(shù)據(jù)總數(shù)這個字段傳給接口屡限,即:
假設我有一個變量totalNum品嚣,用于保存每一次接口返回的數(shù)據(jù)總數(shù);
$.ajax({
    url: '.../orders/my',
    data: {
     num: totalNum,
     ...
    },
    type: 'get',
    cache: false
  });

在實際的項目中钧大,我定義了一個reducer變量用于保存這個數(shù)據(jù)總數(shù)翰撑,在接口的成功回調函數(shù)中,會修改這個reducer啊央。我天真的以為:

我一開始在state中取到的這個reducer數(shù)據(jù)(totalNum)眶诈,雖然在window.onscroll中綁定了,但每次scroll時瓜饥,都會重新從state中取最新的totalNum逝撬。

上面的描述可能比較抽象,下面列出了一個很簡單的模型:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <script type="text/javascript" src="./jquery.min_44f7138.js"></script>
</head>
<body>
  <button class="js-btn">點擊</button>
  <script>
  var totalNum = 1;
  function funClick() {
    var totalNum2 = totalNum;
    return function() {
      $('.js-btn').click(function(){
        alert(totalNum2);
      });
    }
  }

  setTimeout(function(){
    totalNum = 5;
    console.log('setTimeout success 1');
  },5000);

  var param = funClick();
  $(function(){
    param();
  });
</script>
</body>
</html>

上面的這段代碼:

  • 在頁面初始化完成時乓土,點擊按鈕宪潮,這個時候alert出來1,這個大家肯定都沒問題趣苏;

  • 那么狡相,當過了5s中,定時器執(zhí)行完 totalNum = 5后食磕,這個時候會彈出什么結果呢尽棕? 答案還是1,不是5彬伦。

希望看到這篇文章能對你有用~

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末滔悉,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子单绑,更是在濱河造成了極大的恐慌氧敢,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件询张,死亡現(xiàn)場離奇詭異,居然都是意外死亡浙炼,警方通過查閱死者的電腦和手機份氧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來弯屈,“玉大人蜗帜,你說我怎么就攤上這事∽世鳎” “怎么了厅缺?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我湘捎,道長诀豁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任窥妇,我火速辦了婚禮舷胜,結果婚禮上,老公的妹妹穿的比我還像新娘活翩。我一直安慰自己烹骨,他們只是感情好,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布材泄。 她就那樣靜靜地躺著沮焕,像睡著了一般。 火紅的嫁衣襯著肌膚如雪拉宗。 梳的紋絲不亂的頭發(fā)上峦树,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天,我揣著相機與錄音簿废,去河邊找鬼空入。 笑死,一個胖子當著我的面吹牛族檬,可吹牛的內容都是我干的歪赢。 我是一名探鬼主播,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼单料,長吁一口氣:“原來是場噩夢啊……” “哼埋凯!你這毒婦竟也來了?” 一聲冷哼從身側響起扫尖,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤白对,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后换怖,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體甩恼,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年沉颂,在試婚紗的時候發(fā)現(xiàn)自己被綠了条摸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡铸屉,死狀恐怖钉蒲,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情彻坛,我是刑警寧澤顷啼,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布踏枣,位于F島的核電站,受9級特大地震影響钙蒙,放射性物質發(fā)生泄漏茵瀑。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一仪搔、第九天 我趴在偏房一處隱蔽的房頂上張望瘾婿。 院中可真熱鬧,春花似錦烤咧、人聲如沸偏陪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽笛谦。三九已至,卻和暖如春昌阿,著一層夾襖步出監(jiān)牢的瞬間饥脑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工懦冰, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留灶轰,地道東北人。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓刷钢,卻偏偏與公主長得像笋颤,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子内地,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內容