欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中的DSL元編程介紹

 更新時間:2015年03月15日 12:40:25   投稿:junjie  
這篇文章主要介紹了JavaScript中的DSL元編程介紹,本文講解了JavaScript元編程、JavaScript eval、JavaScript new Function()等內(nèi)容,需要的朋友可以參考下

在看JavaScript Template源碼的時候,發(fā)現(xiàn)有一個很有意思的用法用來生成函數(shù),想到這不就是元編程么?

JavaScript 元編程

復制代碼 代碼如下:

 元編程(Metaprogramming)是指某類計算機程序的編寫,這類計算機程序編寫或者操縱其他程序(或者自身)作為它們的數(shù)據(jù),或者在運行時完成部分本應在編譯時完成的工作。

JavaScript eval

復制代碼 代碼如下:

 eval() 函數(shù)可計算某個字符串,并執(zhí)行其中的的 JavaScript 代碼。

可以有下面的用法:
復制代碼 代碼如下:

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

當然這只是用來執(zhí)行某個函數(shù),只是這貨性價比可低了,而且還容易出錯。
復制代碼 代碼如下:

 eval 函數(shù)應該盡可能地避免使用。

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

使用New Function()和eval()的很大一個區(qū)別是,eval不僅僅是一個函數(shù) ,

復制代碼 代碼如下:

 eval() 計算一個字符串作為當前執(zhí)行范圍內(nèi)JavaScript表達式,可以訪問本地變量。 New Function() 解析存儲在一個字符串轉(zhuǎn)換成一個函數(shù)對象,然后可以調(diào)用的JavaScript代碼。因為代碼在一個單獨的范圍內(nèi)運行,不能訪問本地變量。

也就是說eval()會干擾到當前函數(shù)的作用域。。

JavaScript new Function()

 Function 構造器創(chuàng)建一個新的Function 對象. 在JavaScript中每個函數(shù)(function)實際是一個Function對象. 使用Function構造器生成的Function對象是在函數(shù)創(chuàng)建時被解析的。這比你使用函數(shù)聲明(function)并在你的代碼中調(diào)用低效,因為使用函數(shù)語句聲明的function是跟其他語句一起解析的。

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

一個簡單的示例如下所示:

復制代碼 代碼如下:

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

new Function()會將字符串解析為函數(shù)。。然后我們可以通過apply來執(zhí)行
復制代碼 代碼如下:

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;"
    );

當然我們還有其他方法。

相關文章

  • javascript隨機之洗牌算法深入分析

    javascript隨機之洗牌算法深入分析

    這篇文章主要介紹了javascript隨機之洗牌算法深入分析,同時提供了一個完整實例,需要的朋友可以參考下
    2014-06-06
  • GoJs分組繪圖模板go.Group使用示例詳解

    GoJs分組繪圖模板go.Group使用示例詳解

    這篇文章主要為大家介紹了GoJs分組繪圖模板go.Group使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04
  • JavaScript 不只是腳本

    JavaScript 不只是腳本

    JavaScript 不只是腳本...
    2007-05-05
  • js字符串截取函數(shù)substr substring slice使用對比

    js字符串截取函數(shù)substr substring slice使用對比

    字符串截取函數(shù)有substr、substring以及slice等等,下面將為大家介紹下各自的使用,感興趣的朋友可以了解下
    2013-11-11
  • 詳解webpack babel的配置

    詳解webpack babel的配置

    本篇文章主要介紹了詳解webpack babel的配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • js?scrollTop如何到達指定位置

    js?scrollTop如何到達指定位置

    很早之前就想分享這篇心得,幸之今天能在這里完成,好了,話不多說,進入正題。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • js chrome瀏覽器判斷代碼

    js chrome瀏覽器判斷代碼

    今天發(fā)現(xiàn)chrome還是有一些獨一無二的東西,基于它們,我們就可以搞出基于特征的判定了。
    2010-03-03
  • JavaScript中關于class的調(diào)用方法

    JavaScript中關于class的調(diào)用方法

    下面小編就為大家?guī)硪黄琂avaScript中關于class的調(diào)用方法。具有很好的參考價值,希望對大家有所幫助
    2017-11-11
  • 一文了解你不知道的JavaScript生成器篇

    一文了解你不知道的JavaScript生成器篇

    ES6引入了一個新的函數(shù)類型,發(fā)現(xiàn)它并不符合這種運行到結束的特性。這類新的函數(shù)被稱為生成器。生成器的出現(xiàn)是我們知道原來有時代碼并不會順利的運行,可以通過暫停的方式進行異步回調(diào),讓我們摒棄了此前的認知。本文就來聊聊JavaScript中生成器的相關知識
    2022-11-11
  • 實現(xiàn)js保留小數(shù)點后N位的代碼

    實現(xiàn)js保留小數(shù)點后N位的代碼

    最近在做項目的時候,遇到要保留小數(shù)點后N位的問題,經(jīng)過一番思索,最終完成了,這里記錄一下,下次需要直接就能拉出來用了
    2014-11-11

最新評論