国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

JavaScript探秘:eval()是“魔鬼”

來源:懂視網 責編:小采 時間:2020-11-27 20:30:32
文檔

JavaScript探秘:eval()是“魔鬼”

JavaScript探秘:eval()是魔鬼:如果你現在的代碼中使用了eval(),記住該咒語eval()是魔鬼。此方法接受任意的字符串,并當作JavaScript代碼來處理。當有問題的代碼是事先知道的(不是運行時確定的),沒有理由使用eval()。如果代碼是在運行時動態生成,有一個更好的方式不使用eval而
推薦度:
導讀JavaScript探秘:eval()是魔鬼:如果你現在的代碼中使用了eval(),記住該咒語eval()是魔鬼。此方法接受任意的字符串,并當作JavaScript代碼來處理。當有問題的代碼是事先知道的(不是運行時確定的),沒有理由使用eval()。如果代碼是在運行時動態生成,有一個更好的方式不使用eval而

如果你現在的代碼中使用了eval(),記住該咒語“eval()是魔鬼”。此方法接受任意的字符串,并當作JavaScript代碼來處理。當有問題的代碼是事先知道的(不是運行時確定的),沒有理由使用eval()。如果代碼是在運行時動態生成,有一個更好的方式不使用eval而達到同樣的目標。例如,用方括號表示法來訪問動態屬性會更好更簡單:

// 反面示例
var property = "name";
alert(eval("obj." + property));
 
// 更好的
var property = "name";
alert(obj[property]);

使用eval()也帶來了安全隱患,因為被執行的代碼(例如從網絡來)可能已被篡改。這是個很常見的反面教材,當處理Ajax請求得到的JSON 相應的時候。在這些情況下,最好使用JavaScript內置方法來解析JSON相應,以確保安全和有效。若瀏覽器不支持JSON.parse(),你可以使用來自JSON.org的庫。

同樣重要的是要記住,給setInterval(), setTimeout()和Function()構造函數傳遞字符串,大部分情況下,與使用eval()是類似的,因此要避免。在幕后,JavaScript仍需要評估和執行你給程序傳遞的字符串:

// 反面示例
setTimeout("myFunc()", 1000);
setTimeout("myFunc(1, 2, 3)", 1000);
 
// 更好的
setTimeout(myFunc, 1000);
setTimeout(function () {
 myFunc(1, 2, 3);
}, 1000);

使用新的Function()構造就類似于eval(),應小心接近。這可能是一個強大的構造,但往往被誤用。如果你絕對必須使用eval(),你可以考慮使用new Function()代替。有一個小的潛在好處,因為在新Function()中作代碼評估是在局部函數作用域中運行,所以代碼中任何被評估的通過var 定義的變量都不會自動變成全局變量。另一種方法來阻止自動全局變量是封裝eval()調用到一個即時函數中。

考慮下面這個例子,這里僅un作為全局變量污染了命名空間。

console.log(typeof un); // "undefined"
console.log(typeof deux); // "undefined"
console.log(typeof trois); // "undefined"
 
var jsstring = "var un = 1; console.log(un);";
eval(jsstring); // logs "1"
 
jsstring = "var deux = 2; console.log(deux);";
new Function(jsstring)(); // logs "2"
 
jsstring = "var trois = 3; console.log(trois);";
(function () {
 eval(jsstring);
}()); // logs "3"
 
console.log(typeof un); // number
console.log(typeof deux); // "undefined"
console.log(typeof trois); // "undefined"

另一間eval()和Function構造不同的是eval()可以干擾作用域鏈,而Function()更安分守己些。不管你在哪里執行 Function(),它只看到全局作用域。所以其能很好的避免本地變量污染。在下面這個例子中,eval()可以訪問和修改它外部作用域中的變量,這是 Function做不來的(注意到使用Function和new Function是相同的)。

(function () {
 var local = 1;
 eval("local = 3; console.log(local)"); // logs "3"
 console.log(local); // logs "3"
}());
 
(function () {
 var local = 1;
 Function("console.log(typeof local);")(); // logs undefined
}());

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript探秘:eval()是“魔鬼”

JavaScript探秘:eval()是魔鬼:如果你現在的代碼中使用了eval(),記住該咒語eval()是魔鬼。此方法接受任意的字符串,并當作JavaScript代碼來處理。當有問題的代碼是事先知道的(不是運行時確定的),沒有理由使用eval()。如果代碼是在運行時動態生成,有一個更好的方式不使用eval而
推薦度:
標簽: js javascript 魔鬼
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 黄色毛片免费观看 | 国产精品视_精品国产免费 国产精品视频第一区二区三区 | 中文国产成人精品久久久 | 一边摸一边叫床一边爽视频 | 国产91一区二这在线播放 | 国产区一区二 | 亚洲国产天堂久久九九九 | 国产视频不卡 | 国产不卡一区二区三区免费视 | 亚洲欧美日韩综合在线 | 一久久 | 日韩国产欧美视频 | 欧美日韩视频一区二区三区 | 久久久久亚洲精品成人网小说 | 91发布页 | 国产在线视频网 | 日韩在线1 | 国产高清在线免费 | 国产欧美综合在线观看第七页 | 日本国产在线观看 | 成人欧美日韩 | 欧美日韩精品一区二区三区高清视频 | 91大神在线精品视频一区 | 亚洲 欧美 日韩 在线 | 亚洲成人99| 亚洲娇小性色xxxx | 亚洲日本激情综合在线观看 | 自怕偷自怕亚洲精品 | 日韩在线观看一区 | 久久精品免费观看 | 韩国一区二区三区 | 久久午夜一区二区 | 国产区在线免费观看 | 亚洲欧美日韩激情在线观看 | 亚洲精品视频区 | 欧美性猛交xxx乱大交 | 久久国产毛片 | 在线观看免费国产 | 香蕉乱码成人久久天堂爱免费 | 国产一级一级一级成人毛片 | 国产视频在 |