亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

用 promises 和 undefined var 理解奇怪的錯誤

用 promises 和 undefined var 理解奇怪的錯誤

蝴蝶刀刀 2022-10-08 15:04:46
我剛剛發現當幾乎同時觸發 2 個請求時,我的 API 正在做一些奇怪的事情。我發現問題是我在下面的“用戶”變量之前缺少“var”聲明,但我真的很好奇導致下面描述的錯誤的根本問題:我有兩個 API 端點調用相同的函數,如下所示:router.get('/refresh_session_token', function (req, res) {   let user_id = req.body.user_id // The value sent is 8   findUserWithId(user_id)    .then(user_data => {      user = user_data // I forgot 'var' here    })    .then(() => {      console.log(user) // This should always show user data from user_id = 8    })}router.get('/resend_invite', function (req, res) {   let user_id = req.body.user_id // The value sent is 18   findUserWithId(user_id)    .then(user_data => {      user = user_data // I forgot 'var' here    })    .then(() => {      console.log(user) // This should always show user data from user_id = 18    })}const findUserWithId = (id) => {  return knex.raw(`SELECT * FROM users WHERE id = ?`, [id]).then((data) => data.rows[0])}所有這些代碼都在我通過 module.exports = router; 導出的同一個文件中我發現,如果我幾乎同時觸發端點/refresh_session_token和/resend_invite,每個端點都有兩個不同的 user_id,有時我的 console.log 會返回相同的結果,就好像我使用相同的 user_id 一樣。向用戶添加 var 解決了這個問題,但我對后臺實際發生的事情感到非常驚訝。你有什么主意嗎?
查看完整描述

1 回答

?
守候你守候我

TA貢獻1802條經驗 獲得超10個贊

當你沒有聲明你的變量并且你沒有在 Javascriptstrict模式下運行你的模塊時,那么首先分配給該變量:

user = user_data

創建一個名為 的自動全局變量user。這意味著您的兩條路線將共享同一個變量。

而且,由于您的兩條路由都具有異步操作,即使是單線程的東西,您的兩條路由仍然可以同時進行,并且都嘗試使用相同的全局變量。一條路線將覆蓋另一條路線的值。這在基于服務器的代碼中是一場災難,因為通常,在您投入生產之前,該錯誤不會出現,而且很難找到可重現的案例。

最好的答案是始終在嚴格模式下運行代碼,然后 JS 解釋器會將其設為錯誤,并且您將永遠不會被允許以這種方式運行代碼。錯誤將很快被發現。

let那么顯然,總是用or聲明變量const。很少有理由再使用varasletconst讓您更好地控制變量的范圍。

要在嚴格模式下運行您的模塊,請插入:

'use strict';

在任何其他 Javascript 語句之前。

或者,使用 TypeScript 之類的東西,它不會讓你做一些草率的事情,比如不聲明你的變量。


查看完整回答
反對 回復 2022-10-08
  • 1 回答
  • 0 關注
  • 116 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號