」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > JavaScript 中的 eval() 和 new Function() 真的可以互換嗎?

JavaScript 中的 eval() 和 new Function() 真的可以互換嗎?

發佈於2024-11-20
瀏覽:546

Are `eval()` and `new Function()` Truly Interchangeable in JavaScript?

深入探討差異:JavaScript 中 eval() 和 new Function() 可以互換嗎?

在 JavaScript 中,我們常遇到這樣的函數eval() 和 new Function()。雖然它們的語法乍看之下似乎很相似,但仔細檢查就會發現它們的行為有根本差異。

考慮以下單語句函數:

var evaluate = function(string) {
    return eval('('   string   ')');
}

var func = function(string) {
    return (new Function( 'return ('   string   ')' )());
}

console.log(evaluate('2   1'));
console.log(func('2   1'));

這兩個函數的運算是否相同?與流行的看法相反,它們不是。

eval() vs. new Function()

  • eval():解釋目前執行範圍內作為JavaScript 表達式的字串。它具有訪問局部變數的能力。
  • new Function():從包含 JavaScript 程式碼的字串建構子物件。該函數在單獨的作用域中運行,將其與局部變數隔離。

為了說明這個差異,請考慮下列函數:

function test1() {
    var a = 11;
    eval('(a = 22)');
    alert(a);            // alerts 22
}

在此範例中,eval() 修改了 test1() 函數中的局部變數 'a',導致警報為 22。但是,如果我們使用 new Function('return (a = 22);')(),局部變數'a'將保持不變。

含義和注意事項

雖然eval() 和new Function() 都達到了各自的目的,但值得注意的是eval() 具有固有的安全風險。它存取局部變數並可能修改全域範圍的能力可能會導致意想不到的後果。

因此,除非絕對必要,否則通常建議避免使用 eval()。傳遞到 eval() 的不受信任的資料可能會損害應用程式的安全性。同樣,在處理不受信任的輸入時應謹慎使用 new Function()。

最新教學 更多>
  • 如何在 CSS 中使用 :after 和 :hover 動態設定清單項目的樣式?
    如何在 CSS 中使用 :after 和 :hover 動態設定清單項目的樣式?
    結合:after 和:hover 進行動態列表樣式在CSS 中,將:after 等偽元素與懸停狀態結合起來可以增強清單項目的視覺效果。假設您有一個列表,其中所選項目使用 :after 顯示箭頭形狀。若要為懸停的項目實現類似的效果,請按照下列步驟操作:提供的CSS 代碼定義了一個樣式列表,其中所有列表...
    程式設計 發佈於2024-11-20
  • 如何在不阻塞 UI 執行緒的情況下在 WPF 操作中引入延遲?
    如何在不阻塞 UI 執行緒的情況下在 WPF 操作中引入延遲?
    使用替代方法在WPF 操作中實現延遲當嘗試在WPF 中執行操作之前引入延遲時,避免使用Thread.Sleep 很重要,因為這方法會阻塞UI 執行緒並可能導致使用者介面無回應。相反,請考慮利用非同步程式技術。 DispatcherTimer 方法一個選擇是使用 DispatcherTimer。此計時...
    程式設計 發佈於2024-11-20
  • 如何在 PHP 中使用 cURL 將 POST 資料傳送到 URL?
    如何在 PHP 中使用 cURL 將 POST 資料傳送到 URL?
    在PHP 中將POST 資料傳送至URL當您需要在不依賴HTML 表單的情況下將POST 資料傳送至URL時,PHP 的cURL 擴充提供了一個強大的解決方案。實作方法如下:使用 cURL:使用curl_init( $url ) 初始化 cURL 會話。將 $url 替換為目標 URL。 將 CUR...
    程式設計 發佈於2024-11-20
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-20
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-20
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-20
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-11-20
  • 如何在 MySQL 中確定一週的第一天?
    如何在 MySQL 中確定一週的第一天?
    在MySQL 中確定一周的第一天使用日期範圍時,通常需要確定一周的第一天對於給定的日期。在 MySQL 中,根據所需的一週開始日期有不同的方法。 從星期日開始一周獲取從開始的一周的第一天星期日,使用以下公式:DATE_ADD(mydate, INTERVAL(1-DAYOFWEEK(mydate))...
    程式設計 發佈於2024-11-20
  • 哪個呼叫約定負責堆疊清理?
    哪個呼叫約定負責堆疊清理?
    調用約定:stdcall 與 cdecl在程式設計中,呼叫約定定義參數如何在函數之間傳遞。兩個常見的呼叫約定是 stdcall 和 cdecl.1。 cdecl函式呼叫當呼叫cdecl函式時,呼叫者不負責清理堆疊。編譯器根據函數的呼叫約定產生處理堆疊清理的程式碼。 2。混合呼叫約定通常不建議混合呼叫...
    程式設計 發佈於2024-11-20
  • 儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    儘管程式碼有效,為什麼 POST 請求無法擷取 PHP 中的輸入?
    解決PHP 中的POST 請求故障在提供的程式碼片段中:action=''而非:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"檢查$_POST陣列:表單提交後使用 var_dump 檢查 $_POST 陣列的內...
    程式設計 發佈於2024-11-20
  • 為什麼 Go 函數不能直接傳回多個值?
    為什麼 Go 函數不能直接傳回多個值?
    Go 傳回多個值問題當嘗試在 Go 中傳回多個值時,為什麼某些語法有效而其他語法無效似乎令人困惑。為了說明這一點,請考慮以下兩個程式碼片段:func FindUserInfo(id string) (Info, bool) { it, present := all[id] retur...
    程式設計 發佈於2024-11-20
  • 為什麼在使用 `go` 語句時要在主 Goroutine 中計算 `input.Text()` ?
    為什麼在使用 `go` 語句時要在主 Goroutine 中計算 `input.Text()` ?
    為什麼在主Goroutine 中計算input.Text()在Go 程式語言的第8 章中,以下語句是關於並發echo 伺服器:由go 啟動的函數的參數在執行go 語句本身時進行評估;因此input.Text() 在主goroutine 中被求值。 這條語句的意思是,當執行 go 語句時,立即對 in...
    程式設計 發佈於2024-11-20
  • 為什麼我的Go HTTP客戶端造訪Github時提示「您對該網站的存取已被限制」?
    為什麼我的Go HTTP客戶端造訪Github時提示「您對該網站的存取已被限制」?
    解決Go HTTP 用戶端中「您對該網站的存取已被限制」的問題使用Go 的HTTP 用戶端訪問Github 資源可能會觸發「您對該網站的存取已被限制」錯誤。在 AWS 上執行的 EC2 執行個體中從 Github 檢索 tar.gz 等檔案時,尤其會遇到此問題。 潛在原因問題可能源自於過時的軟體配置...
    程式設計 發佈於2024-11-20
  • 如何在 AngularJS 的 ng-options 中設定 value 屬性?
    如何在 AngularJS 的 ng-options 中設定 value 屬性?
    在 AngularJS 的 ng-options 中設定值AngularJS 的 ng-options 指令允許開發人員填入 標籤的選項。出現的一個常見問題是如何為每個選項設定 value 屬性。 為了理解值設定機制,讓我們深入研究 ngOptions 的語法。它採用以下形式之一的表達式:對於數組...
    程式設計 發佈於2024-11-20
  • 如何在不犧牲索引的情況下最佳化 MySQL 中帶有前導通配符的「LIKE」查詢?
    如何在不犧牲索引的情況下最佳化 MySQL 中帶有前導通配符的「LIKE」查詢?
    在不影響索引的情況下使用「like」和通配符優化MySQL 搜尋在資料庫最佳化領域,使用「like」運算符的查詢前導通配符,例如“SELECT * FROM sometable WHERE somefield LIKE '%value%'”,通常會為索引利用帶來挑戰。本文探討了一種最...
    程式設計 發佈於2024-11-20

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3