亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js中eval方法詳解之eval方法的初級(jí)應(yīng)用

 更新時(shí)間:2023年01月16日 14:24:36   作者:野生程序員--小陽(yáng)  
js中eval()函數(shù)可計(jì)算某個(gè)字符串,下面這篇文章主要給大家介紹了關(guān)于js中eval方法詳解之eval方法的初級(jí)應(yīng)用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

在我看來(lái),js中的eval()方法就是一個(gè)js語(yǔ)言的執(zhí)行器,它能把其中的參數(shù)按照J(rèn)avaScript語(yǔ)法進(jìn)行解析并執(zhí)行。

語(yǔ)法:

eval(s);

eval()方法中的參數(shù)s有多種情況。參數(shù)的不同形式,會(huì)使eval()方法執(zhí)行的結(jié)果和返回值有差別。下面來(lái)說(shuō)說(shuō)他們的區(qū)別。

eval()方法的參數(shù)形式

如果參數(shù)s不是字符串,而是整數(shù)或者是Function類型,則直接返回該整數(shù)或Function

舉個(gè)栗子

例1:

var x = 1;
var y = eval(x);//eval()方法返回1
var z = eval(1)//eval()方法返回1

例2:

var f = eval(
          function(){
            console.log("1111");
            return 1
           }
        );
/*
eval()方法返回:
    function(){console.log("1111");return 1;}方法
*/
var s = f();//執(zhí)行方法  s=1,打印日志"1111"

/**>>>>>>>>>>>>>>>**/

var ff = function(){
   console.log("1111");
   return 1;
};
var f = eval(ff);//eval()方法返回ff方法
var s = ff();//執(zhí)行ff方法  s=1,打印日志"1111"

/**>>>>>>>>>>>>>>>**/

function ff(){
   console.log("1111");
   return 1;
};
var f = eval(ff);//eval()方法返回ff方法
var s = ff();//執(zhí)行ff方法  s=1,打印日志"1111"

如果參數(shù)s是字符串,并且字符串中是表達(dá)式,則eval()方法會(huì)計(jì)算字符串中的表達(dá)式,返回該表達(dá)式計(jì)算的結(jié)果。

舉個(gè)栗子

eval("'true'");//返回字符串"true"
eval("ture");//返回Boolean類型的true
eval("1");//返回整數(shù)1
eval("[0,1,2]");//返回?cái)?shù)組[0,1,2]
eval("2+2");//返回整數(shù)4
eval("2+'2'");//返回字符串"22"

如果參數(shù)s是字符串,并且字符串中的表達(dá)式是JSON格式(此時(shí)的JOSN格式外面要加上一對(duì)小括號(hào)將JSON包圍起來(lái)),則eval()方法返回該JSON。

舉個(gè)栗子

var j = "{'aa':11,'bb':22}";
eval("("+j+")");
//返回{"aa":11,"bb":22}

eval("({'aa':11,'bb':22})");
//返回{"aa":11,"bb":22}

eval("({aa:11,bb:22})");
//js中{aa:11,bb:22}這種格式在解析時(shí)會(huì)轉(zhuǎn)換成{'aa':11,'bb':22}這種格式

eval("{'aa':11,'bb':22}");
//拋出異常

附注

對(duì)于eval()方法,上面所說(shuō)的的JSON格式也是屬于表達(dá)式的一種。但是如果JSON格式中沒(méi)有小括號(hào)包圍,則該eval()方法就不會(huì)返回該對(duì)象。
如:eval(“{‘aa’:11,’bb’:22}”)這種格式,就不會(huì)返回{‘aa’:11,’bb’:22}。

因?yàn)閑val()方法在處理方括號(hào)”{}”時(shí),會(huì)把它當(dāng)成是一個(gè)語(yǔ)句塊。那么eval()方法只會(huì)執(zhí)行該語(yǔ)句,并不會(huì)返回該值(結(jié)果是拋出異常)。

正確的寫(xiě)法是:在JSON格式外加上小括號(hào)”()”,使其強(qiáng)制類型轉(zhuǎn)換成JSON格式(表達(dá)式),并返回該JSON值。這一點(diǎn)和即時(shí)函數(shù)(function(){})()一樣,()的作用也是將該function強(qiáng)制轉(zhuǎn)換成表達(dá)式并返回。

如果參數(shù)s是字符串,并且字符串中是語(yǔ)句或語(yǔ)句塊,則eval()方法會(huì)執(zhí)行該語(yǔ)句或語(yǔ)句塊,并且返回undefined

舉個(gè)栗子

eval("var x='1';");
//返回undefined
console.log(x);
//打印字符串1

/**>>>>>>>>>>>>>>>**/

eval("var x=1;var y=2;var z=x+y;");
//返回undefined
console.log(z+"");
//打印字符串3

/**>>>>>>>>>>>>>>>**/

s = eval("function t(){alert(3)};t();");
//執(zhí)行定義并調(diào)用t的方法:彈出3.并且返回undefined
console.log(s);
//打印undefined

/**>>>>>>>>>>>>>>>**/

eval("var j={sex:'男',age:27};alert(j.age);");
/*
此處的json對(duì)象不用小括號(hào)"()"括起來(lái)。因?yàn)樵撎幨菆?zhí)行語(yǔ)句,而非計(jì)算表達(dá)式
*/

附注

eval()方法中,如果json格式是存在于語(yǔ)句中的,那么該json格式不需要用小括號(hào)”()”括起來(lái)。表達(dá)式中的json要括起來(lái)的原因是,eval()要計(jì)算表達(dá)式并且返回結(jié)果。而eval()對(duì)語(yǔ)句只是執(zhí)行,并不會(huì)計(jì)較返回值(因?yàn)榉祷氐亩际?undefined)

eval()方法的錯(cuò)誤處理機(jī)制

如果eval()參數(shù)中有非法的表達(dá)式和語(yǔ)句,則拋出 SyntaxError 異常。

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

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

注:eval()方法在執(zhí)行js代碼時(shí)可能會(huì)出現(xiàn)異常,所以最好用try…catch語(yǔ)句來(lái)執(zhí)行eval()方法

舉個(gè)栗子

例1:

var y = "var s = '1ss';s.replace('1','s')";
try{
    eval(y);//執(zhí)行該方法
}catch(exception){
    console.warn(exception);
}

例2:

var y = "var s = 1ss;s.replace('1','s')";
try{
    eval(y);//拋出異常
}catch(exception){
    console.warn(exception);
    //打?。篣nexpected token ILLEGAL
}

例3:

var y = "var s = 1ss;s.replace('1','s')";
try{
    var zz = eval;
    zz(y);//執(zhí)行該方法
}catch(exception){
    console.warn(exception);
}

注意:

使用eval會(huì)有很多問(wèn)題,如果想要實(shí)現(xiàn)轉(zhuǎn)化,可以使用JSON.parse,如果后臺(tái)返回為JSON對(duì)象,則直接使用data就可以。如果使用jq,則將type設(shè)置為json,或者利用$.getJSON()方法獲得服務(wù)器返回,就不需要eval方法了

使用eval轉(zhuǎn)化時(shí)為什么要添加括號(hào)

這是eval自身的問(wèn)題。由于json是以{}的方式來(lái)開(kāi)始以及結(jié)束的,在js中,它會(huì)被當(dāng)成一個(gè)語(yǔ)句塊來(lái)處理,所以必須強(qiáng)制性的將它轉(zhuǎn)化成一種表達(dá)式。加上()是迫使eval函數(shù)在處理js代碼的時(shí)候強(qiáng)制將{}內(nèi)的表達(dá)式轉(zhuǎn)化為對(duì)象,而不是作為語(yǔ)句來(lái)執(zhí)行。

總結(jié)

到此這篇關(guān)于js中eval方法詳解之eval方法的初級(jí)應(yīng)用的文章就介紹到這了,更多相關(guān)js中eval方法初級(jí)應(yīng)用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js省市縣三級(jí)聯(lián)動(dòng)效果實(shí)例

    js省市縣三級(jí)聯(lián)動(dòng)效果實(shí)例

    這篇文章主要介紹了js實(shí)現(xiàn)簡(jiǎn)單的省市縣三級(jí)聯(lián)動(dòng)效果,以完整實(shí)例形式分析了JavaScript實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)效果的具體步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-05-05
  • textarea不能通過(guò)maxlength屬性來(lái)限制字?jǐn)?shù)的解決方法

    textarea不能通過(guò)maxlength屬性來(lái)限制字?jǐn)?shù)的解決方法

    textarea稱文本域,又稱文本區(qū),其不能通過(guò)maxlength屬性來(lái)限制字?jǐn)?shù),為此必須尋求其他方法來(lái)加以限制以達(dá)到預(yù)設(shè)的需求
    2014-09-09
  • JavaScript ECMA-262-3 深入解析(一):執(zhí)行上下文實(shí)例分析

    JavaScript ECMA-262-3 深入解析(一):執(zhí)行上下文實(shí)例分析

    這篇文章主要介紹了JavaScript ECMA-262-3 執(zhí)行上下文,結(jié)合實(shí)例形式詳細(xì)分析JavaScript ECMA執(zhí)行上下文相關(guān)概念、原理與操作注意事項(xiàng),需要的朋友可以參考下
    2020-04-04
  • JS組件Bootstrap Table使用實(shí)例分享

    JS組件Bootstrap Table使用實(shí)例分享

    這篇文章主要為大家詳細(xì)介紹了JS組件Bootstrap Table分頁(yè)使用方法,具有一定的實(shí)用性,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Bootstrap按鈕組實(shí)例詳解

    Bootstrap按鈕組實(shí)例詳解

    單個(gè)按鈕在Web頁(yè)面中的運(yùn)用有時(shí)候并不能滿足我們的業(yè)務(wù)需求,常常會(huì)看到將多個(gè)按鈕組合在一起使用,比如富文本編輯器里的一組小圖標(biāo)按鈕等。本文將詳細(xì)介紹Bootstrap按鈕組,感興趣的朋友一起看看吧
    2017-07-07
  • javascript 組合按鍵事件監(jiān)聽(tīng)實(shí)現(xiàn)代碼

    javascript 組合按鍵事件監(jiān)聽(tīng)實(shí)現(xiàn)代碼

    這篇文章主要介紹了javascript 組合按鍵事件監(jiān)聽(tīng)實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • gojs實(shí)現(xiàn)螞蟻線動(dòng)畫(huà)效果

    gojs實(shí)現(xiàn)螞蟻線動(dòng)畫(huà)效果

    這篇文章介紹了gojs實(shí)現(xiàn)螞蟻線動(dòng)畫(huà)效果的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • 基于JavaScript實(shí)現(xiàn)仿京東圖片輪播效果

    基于JavaScript實(shí)現(xiàn)仿京東圖片輪播效果

    這篇文章主要介紹了基于JavaScript實(shí)現(xiàn)仿京東圖片輪播效果,代碼簡(jiǎn)單易懂,需要的小伙伴參考下吧
    2015-11-11
  • 使用webpack編譯es6代碼的方法步驟

    使用webpack編譯es6代碼的方法步驟

    這篇文章主要介紹了使用webpack編譯es6代碼的方法步驟,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-04-04
  • 詳解JavaScript設(shè)計(jì)模式中的享元模式

    詳解JavaScript設(shè)計(jì)模式中的享元模式

    享元模式是一種用于性能優(yōu)化的模式。享元模式的核心是運(yùn)用共享技術(shù)來(lái)有效支持大量細(xì)粒度的對(duì)象.如果系統(tǒng)中創(chuàng)建了大量類似的對(duì)象而導(dǎo)致內(nèi)存占用過(guò)高,本文通過(guò)介紹書(shū)中文件上傳的優(yōu)化案例來(lái)說(shuō)明享元模式的使用方式和作用,需要的朋友可以參考下
    2023-06-06

最新評(píng)論