首頁 web前端 js教程 JavaScript中的DSL元程式設計介紹_javascript技巧

JavaScript中的DSL元程式設計介紹_javascript技巧

May 16, 2016 pm 04:09 PM
javascript 元程式設計

在看JavaScript Template原始碼的時候,發現有一個很有趣的用法用來產生函數,想到這不就是元程式設計麼?

JavaScript 元程式設計

複製程式碼 程式碼如下:

 元程式設計(Metaprogramming)是指某類電腦程式的編寫,這類電腦程式編寫或操縱其他程式(或本身)作為它們的數據,或是在執行時間完成部分本應在編譯時完成的工作。

JavaScript eval

複製程式碼 程式碼如下:

 eval() 函數可計算某個字串,並執行其中的 JavaScript 程式碼。

可以有下面的用法:
複製程式碼 程式碼如下:

eval("x=10;y=20;document.write(x*y)")

當然這只是用來執行某個函數,只是這貨性價比可低了,而且還容易出錯。
複製程式碼 程式碼如下:

 eval 函數應該盡可能地避免使用。

於是更好地方法是使用New Function()

使用New Function()和eval()的很大一個區別是,eval不只是一個函數 ,

複製程式碼 程式碼如下:

 eval() 計算一個字串作為目前執行範圍內JavaScript表達式,可以存取本機變數。 New Function() 解析儲存在一個字串轉換成一個函數對象,然後可以呼叫的JavaScript程式碼。因為程式碼在一個單獨的範圍內運行,不能存取本地變數。

也就是說eval()會幹擾到目前函數的作用域。 。

JavaScript new Function()

 Function 建構器建立一個新的Function 物件. 在JavaScript中每個函數(function)實際上是一個Function物件. 使用Function建構器產生的Function物件是在函數建立時被解析的。這比你使用函數宣告(function)並在你的程式碼中呼叫低效,因為使用函數語句宣告的function是跟其他語句一起解析的。

New Function() 相較之下會比較低效,而這也是目前情況下我們所能預知的。

一個簡單的範例如下:

複製程式碼 程式碼如下:

var add = new Function(['x', 'y'], 'return x y');

new Function()會將字串解析為函數。 。然後我們可以透過apply來執行
複製程式碼 程式碼如下:

Function.apply(null, args)

而這也是我在JavaScript Template中所看到的:
複製程式碼 程式碼如下:

   new Function(
        tmpl.arg ',tmpl',
        "var _e=tmpl.encode" tmpl.helper ",_s='"
        str.replace(tmpl.regexp, tmpl.func)
        "';return _s;"
    );

當然我們還有其他方法。
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何使用WebSocket和JavaScript實現線上語音辨識系統 如何使用WebSocket和JavaScript實現線上語音辨識系統 Dec 17, 2023 pm 02:54 PM

如何使用WebSocket和JavaScript實現線上語音辨識系統

WebSocket與JavaScript:實現即時監控系統的關鍵技術 WebSocket與JavaScript:實現即時監控系統的關鍵技術 Dec 17, 2023 pm 05:30 PM

WebSocket與JavaScript:實現即時監控系統的關鍵技術

如何使用WebSocket和JavaScript實現線上預約系統 如何使用WebSocket和JavaScript實現線上預約系統 Dec 17, 2023 am 09:39 AM

如何使用WebSocket和JavaScript實現線上預約系統

如何利用JavaScript和WebSocket實現即時線上點餐系統 如何利用JavaScript和WebSocket實現即時線上點餐系統 Dec 17, 2023 pm 12:09 PM

如何利用JavaScript和WebSocket實現即時線上點餐系統

簡易JavaScript教學:取得HTTP狀態碼的方法 簡易JavaScript教學:取得HTTP狀態碼的方法 Jan 05, 2024 pm 06:08 PM

簡易JavaScript教學:取得HTTP狀態碼的方法

JavaScript與WebSocket:打造高效率的即時天氣預報系統 JavaScript與WebSocket:打造高效率的即時天氣預報系統 Dec 17, 2023 pm 05:13 PM

JavaScript與WebSocket:打造高效率的即時天氣預報系統

如何在JavaScript中取得HTTP狀態碼的簡單方法 如何在JavaScript中取得HTTP狀態碼的簡單方法 Jan 05, 2024 pm 01:37 PM

如何在JavaScript中取得HTTP狀態碼的簡單方法

golang 反射在元程式設計和程式碼產生的應用 golang 反射在元程式設計和程式碼產生的應用 May 03, 2024 pm 09:30 PM

golang 反射在元程式設計和程式碼產生的應用

See all articles