歡迎您光臨本站 註冊首頁

JavaScript eval()函數定義及使用方法詳解

←手機掃碼閱讀     madbeef @ 2020-07-08 , reply:0

定義和用法
 

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

語法
 

eval(string)
 

返回值
 

通過計算 string 得到的值(如果有的話)。

說明
 

該方法只接受原始字符串作為參數,如果 string 參數不是原始字符串,那麼該方法將不作任何改變地返回。因此請不要為 eval() 函數傳遞 String 對象來作為參數。

如果試圖覆蓋 eval 屬性或把 eval() 方法賦予另一個屬性,並通過該屬性調用它,則 ECMAScript 實現允許拋出一個 EvalError 異常。

拋出
 

如果參數中沒有合法的表達式和語句,則拋出 SyntaxError 異常。

如果非法調用 eval(),則拋出 EvalError 異常。

如果傳遞給 eval() 的 Javascript 代碼生成了一個異常,eval() 將把該異常傳遞給調用者。

舉例
 

以下代碼可以將"alert('Hello world')"字符串作為參數,轉化成javaScprit代碼進行執行,瀏覽器彈出提示框輸出'Hello world'

  <script type="text/javascript">    var a = "alert('Hello world')"    eval(a)  </script>

 

eval()函數非常強大,我認為它在一定程度上體現出了javaScript這種動態語言的優點。

用這個函數,開發者可以在不改變第三方前端javaScript庫源碼的基礎上,增加功能,或者修改功能,使得程序變得更為靈活。

比如我正在開發一個動態表格的小系統,後臺程序將表中的所有字段,以及所有數據傳遞給前端,前端javaScript代碼接收到數據以後,根據字段自動生成表格。但我正在用第三方(layui)js框架,框架裡渲染表格的代碼必須是固定寫好的,不符合動態生成需求,這個時候,可以使用eval()函數。

下面簡單看一下layui框架表格部分的使用說明

表頭部分需要在javaScript代碼中固定對應寫好,接收到指定數據接口的數據再生成表格。

如果每次需要的表格的字段都不同,列數都不一樣。那麼就可用eval()函數拼接代碼實現了。大致實現思路是,ajax請求到表頭的相關數據,javaScript代碼根據這些數據自動生成符合框架要求的代碼語句,然後傳遞到eval()函數中直接調用就可以了。非常的靈活與方便。
 

比如以下偽代碼

  <script>    var code1 = "layui.use('table', function(){var table = layui.table;table.render({elem: '#demo',height: 312,url: '/demo/table/user/',page: true,cols: [[{"    // ...這裡根據接收到的表各個字段信息自動拼接代碼,形成字符串 code2    var code2 = "field: 'id', title: 'ID', width:80, sort: true, fixed: 'left'},{field: 'username', title: '用戶名', width:80},{field: 'sex', title: '性別', width:80, sort: true},{field: 'city', title: '城市', width:80},{field: 'sign', title: '簽名', width: 80},{field: 'experience', title: '積分', width: 80, sort: true},{field: 'score', title: '評分', width: 80, sort: true},{field: 'classify', title: '職業', width: 80},{field: 'wealth', title: '財富', width: 135, sort: false"    var code3 = "}]]});});"    var code = code1 + code2 + code3    eval(code)  </script>

 

                      

   


[madbeef ] JavaScript eval()函數定義及使用方法詳解已經有363次圍觀

http://coctec.com/docs/javascript/show-post-241805.html