首頁  >  文章  >  web前端  >  如何在 JavaScript 中將字串轉換為函數呼叫而不使用“eval”?

如何在 JavaScript 中將字串轉換為函數呼叫而不使用“eval”?

Mary-Kate Olsen
Mary-Kate Olsen原創
2024-11-02 06:22:02702瀏覽

How to Convert a String into a Function Call in JavaScript Without Using `eval`?

在JavaScript 中將字串轉換為函數呼叫

問題

您有一個表示函數呼叫的字串,例如:

settings.functionName + '(' + t.parentNode.id + ')'

您想要將此字串轉換為實際的函數調用,但不使用eval。

解決方案

您可以使用以下程式碼來取代使用eval:

var fn = window[settings.functionName];
if(typeof fn === 'function') {
    fn(t.parentNode.id);
}

此程式碼:

  1. 透過存取全域視窗物件並使用settings.functionName 屬性作為鍵來取得函數的參考。
  2. 檢查是否得到的值是一個函數。
  3. 如果它是一個函數,則使用所需的參數來呼叫它。

範例

考慮以下設定物件:

/* Somewhere: */
window.settings = {
  /* [..] Other settings */
  functionName: 'clickedOnItem'
  /* , [..] More settings */
};

在程式碼的後面,定義了以下函數:

function clickedOnItem (nodeId) {
  /* Some cool event handling code here */
}

現在,您可以使用解決方案中提供的程式碼來進行函數呼叫:

/* Even later */
var fn = window[settings.functionName]; 
if(typeof fn === 'function') {
    fn(t.parentNode.id);
}

這將導致以t.parentNode.id 作為參數呼叫clickedOnItem 函數。

以上是如何在 JavaScript 中將字串轉換為函數呼叫而不使用“eval”?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn