AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當前位置:首頁 > 科技  > 軟件

盤點JavaScript中Eval函數的使用方法

來源: 責編: 時間:2024-07-11 17:31:16 658觀看
導讀一、前言內建函數 eval 函數允許執行一個代碼字符串。語法 :let result = eval(code);例 :let code = 'alert("Hello")';eval(code); // Hello運行結果:代碼字符串可能會比較長,包含換行符、函數聲明和變量等。eval 的結

一、前言

內建函數 eval 函數允許執行一個代碼字符串。2Ex28資訊網——每日最新資訊28at.com

語法 :

let result = eval(code);

例 :2Ex28資訊網——每日最新資訊28at.com

let code = 'alert("Hello")';eval(code); // Hello

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

代碼字符串可能會比較長,包含換行符、函數聲明和變量等。2Ex28資訊網——每日最新資訊28at.com

eval 的結果是最后一條語句的結果。2Ex28資訊網——每日最新資訊28at.com

例:2Ex28資訊網——每日最新資訊28at.com

let value = eval('1+1');alert(value); // 2let value = eval('let i = 0; ++i');alert(value); // 1

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

eval 內的代碼在當前詞法環境(lexical environment)中執行,因此它能訪問外部變量:2Ex28資訊網——每日最新資訊28at.com

let a = 1;function f() {   let a = 2;  eval('alert(a)');   // 2}  f();

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

它也可以更改外部變量:2Ex28資訊網——每日最新資訊28at.com

let x = 5;eval("x = 10");alert(x); // 10,值被更改了

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

嚴格模式下,eval 有屬于自己的詞法環境。因此不能從外部訪問在 eval 中聲明的函數和變量:2Ex28資訊網——每日最新資訊28at.com

// 提示:本教程所有可運行的示例都默認啟用了嚴格模式 'use strict'eval("let x = 5; function f() {}");alert(typeof x); // undefined(沒有這個變量)// 函數 f 也不可從外部進行訪問

如果不啟用嚴格模式,eval 沒有屬于自己的詞法環境,因此可以從外部訪問變量 x 和函數 f。2Ex28資訊網——每日最新資訊28at.com

二、案例

Eval-計算器

創建一個計算器,提示用戶輸入一個算術表達式,并返回其計算結果。2Ex28資訊網——每日最新資訊28at.com

讓使用 eval 來計算數學表達式:2Ex28資訊網——每日最新資訊28at.com

let expr = prompt("Type an arithmetic expression?", '23+2');alert( eval(expr) );

需要檢查表達式是否正確。只需要計算并返回結果。用戶可以輸入任意文本或代碼。2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

三、使用 “eval”

在 eval 中使用外部局部變量也被認為是一個壞的編程習慣,因為這會使代碼維護變得更加困難。2Ex28資訊網——每日最新資訊28at.com

有兩種方法可以完全避免此類問題。2Ex28資訊網——每日最新資訊28at.com

如果 /eval/ 中的代碼,+沒有使用外部變量,請以 window./eval(...) 的形式調用 /eval/。2Ex28資訊網——每日最新資訊28at.com

通過這種方式,該代碼便會在全局作用域內執行:2Ex28資訊網——每日最新資訊28at.com

let x = 1;{  let x = 5;  window.eval('alert(x)'); // 1(全局變量)}

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

如果 /eval/ 中的代碼需要訪問局部變量,可以使用 new Function 替代 /eval/,并將它們作為參數傳遞:2Ex28資訊網——每日最新資訊28at.com

let f = new Function('a', 'alert(a)');f(5); // 5

運行結果:2Ex28資訊網——每日最新資訊28at.com

2Ex28資訊網——每日最新資訊28at.com

注:2Ex28資訊網——每日最新資訊28at.com

new Function 從字符串創建一個函數,并且也是在全局作用域中的。所以它無法訪問局部變量。2Ex28資訊網——每日最新資訊28at.com

四、總結

本文基于JavaScript基礎,介紹了 Eval函數的使用。調用 eval(code) 會運行代碼字符串,并返回最后一條語句的結果。2Ex28資訊網——每日最新資訊28at.com

要在全局作用域中 eval 代碼,可以使用 window.eval(code) 進行替代。2Ex28資訊網——每日最新資訊28at.com

通過案例的分析,進行詳細的講解。在實際應用中需要注意的點,遇到的難點,提供了詳細的解決方法。使用JavaScript語言,能夠讓讀者更好的理解。代碼很簡單,希望能夠幫助讀者更好的學習。2Ex28資訊網——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-100461-0.html盤點JavaScript中Eval函數的使用方法

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Python 數據類型(如整數、浮點數、字符串、列表、元組、字典)

下一篇: 一文帶您理解Python的map/filter/reduce

標簽:
  • 熱門焦點
Top