js DSL超程式設計簡單介紹
本文介紹一下標題中的相關概念,希望能夠給需要的朋友帶來一定的幫助。
下面進入正題:
一.javascript超程式設計:
超程式設計(Metaprogramming)是指某類計算機程式的編寫,這類計算機程式編寫或者操縱其他程式(或者自身)作為它們的資料,或者在執行時完成部分本應在編譯時完成的工作。
二.javascript eval:
eval() 函式可計算某個字串,並執行其中的的 JavaScript 程式碼。
可以有下面的用法:
[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() 相比之下會比較低效,而這也是當前情況下我們所能預知的。
一個簡單的示例如下所示:
[JavaScript] 純文字檢視 複製程式碼var add = new Function(['x', 'y'], 'return x + y');
new Function()會將字串解析為函式,然後我們可以通過apply來執行
[JavaScript] 純文字檢視 複製程式碼Function.apply(null, args)
而這也是我在JavaScript Template中所看到的:
[JavaScript] 純文字檢視 複製程式碼new Function( tmpl.arg + ',tmpl', "var _e=tmpl.encode" + tmpl.helper + ",_s='" + str.replace(tmpl.regexp, tmpl.func) + "';return _s;" );
當然我們還有其他方法。
相關文章
- 設定XMLHttpRequest超時簡單介紹XMLHTTP
- JavaScript 模組化程式設計簡單介紹JavaScript程式設計
- Linux 程式設計工具簡單介紹Linux程式設計
- MATLAB 超程式設計介紹Matlab程式設計
- JSON簡單介紹JSON
- nodejs簡單介紹NodeJS
- javascript物件導向程式設計概念簡單介紹JavaScript物件程式設計
- javascript函數語言程式設計簡單介紹JavaScript函數程式設計
- javascript如何實現模組程式設計簡單介紹JavaScript程式設計
- 使XML程式設計更簡單---JDOM介紹及程式設計指南 (轉)XML程式設計
- JSON物件簡單介紹JSON物件
- js WebSocket用法簡單介紹JSWeb
- javascript設計模式單例模式簡單介紹JavaScript設計模式單例
- js設定元素background-position簡單介紹JS
- js程式碼執行順序簡單介紹JS
- 設計模式和反模式簡單介紹設計模式
- 簡單介紹python程式設計之檔案讀寫Python程式設計
- js字串連線簡單介紹JS字串
- js cookie路徑簡單介紹JSCookie
- js 特權方法簡單介紹JS
- js短路運算簡單介紹JS
- js與&&運算子簡單介紹JS
- js的表單元素的defaultValue預設值簡單介紹JS
- js如何阻止表單提交簡單介紹JS
- 簡單介紹架構設計的原則!架構
- 好程式設計師web前端培訓分享FormData 簡單介紹程式設計師Web前端ORM
- 002 Rust 非同步程式設計,async await 簡單介紹Rust非同步程式設計AI
- javascript物件導向程式設計關於封裝簡單介紹JavaScript物件程式設計封裝
- 簡單介紹一下 JSONJSON
- angularJS的router用法簡單介紹AngularJS
- js style.cssText用法簡單介紹JSCSS
- js事件委託原理簡單介紹JS事件
- js isPrototypeOf()函式用法簡單介紹JS函式
- node.js操作mongodb簡單介紹Node.jsMongoDB
- ReactJs環境配置簡單介紹ReactJS
- require.js的作用簡單介紹UIJS
- 是什麼JSON,簡單介紹JSON
- JSON的優點簡單介紹JSON