溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

javascript中eval函數(shù)的作用是什么

發(fā)布時間:2021-07-14 16:23:19 來源:億速云 閱讀:1048 作者:Leah 欄目:編程語言

本篇文章給大家分享的是有關(guān)javascript中eval函數(shù)的作用是什么,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。


(1)介紹javascript中的eval函數(shù)的用法
(2)如何在函數(shù)內(nèi)執(zhí)行全局代碼

  • ?先來說eval的用法,內(nèi)容比較簡單,熟悉的可以跳過。
    eval函數(shù)接收一個參數(shù)s,如果s不是字符串,則直接返回s。否則執(zhí)行s語句。如果s語句執(zhí)行結(jié)果是一個值,則返回此值,否則返回undefined。
    需要特別注意的是對象聲明語法“{}”并不能返回一個值,需要用括號括起來才會返回值,簡單示例如下:

    var s='global';    //定義一個全局變量function demo1(){
       eval('var s="local"');
    }
    demo1();
    alert(s);    //->global

    很好理解,上面的demo1函數(shù)等價于:function demo1(){var s='local';},其中定義了一個局部變量s。
           所以最后的輸出是global并不是什么奇怪的事情,畢竟大家都能很清楚的區(qū)分局部變量和全局變量。
           仔細體會一下,可以發(fā)現(xiàn)eval函數(shù)的特點,它總是在調(diào)用它的上下文變量空間(也稱為:包,closure)內(nèi)執(zhí)行,無論是變量定義還是函數(shù)定義都是如此,所以如下的代碼會產(chǎn)生函數(shù)未定義的錯誤:

    var s='function test(){return 1;}';     //一個函數(shù)定義語句function demo2(){
       eval(s);
    }
    demo2();
    alert(test());    //->error:test is not defined

    這是因為test函數(shù)在局部空間定義,demo2函數(shù)內(nèi)可以訪問到,外面就訪問不到了。


            而在實際的Ajax開發(fā)中,有時我們需要從服務(wù)器動態(tài)獲取代碼來執(zhí)行,以減輕一次載入代碼過多的問題,或者是一些代碼是通過Javascript自身生成的,希望用eval函數(shù)來使其執(zhí)行。
    但這樣的動態(tài)獲取代碼的工作一般在函數(shù)內(nèi)完成,比如:

    function loadCode(){
       var code=getCode();
       eval(code);
    }

    可見eval不可能在全局空間內(nèi)執(zhí)行,這就給開發(fā)帶來了不少問題,也看到過很多人為此郁悶。

    不過現(xiàn)在偶終于找到了解決辦法,嘿嘿,可以同時兼容IE和Firefox,方法如下:

    var X2={}    //my namespace:)X2.Eval=function(code){
    if(!!(window.attachEvent && !window.opera)){
     
    //ie  execScript(code);
    }else{
     
    //not ie  window.eval(code);
    }
    }

    現(xiàn)在如果要想在函數(shù)內(nèi)定義全局代碼,就可以通過調(diào)用X2.Eval(code)方法,一個例子如下:

    var s='global';
    function demo3(){
    X2.Eval('var s="local"');
    }
    demo3();
    alert(s); //->'local'

    可見,在demo3函數(shù)內(nèi)重新定義了全局變量s="local"。
           需要注意的是X2.Eval并不返回值,如果要進行表達式的求值,還是用系統(tǒng)的eval函數(shù)。X2.Eval設(shè)計為僅做全局代碼定義用。

    其實看到這里,或許有人感覺問題也太容易解決了點,呵呵,但發(fā)現(xiàn)這個辦法倒是需要些運氣和技巧的:
    (1)對于IE瀏覽器,默認已經(jīng)提供了這樣的函數(shù):execScript,用于在全局空間執(zhí)行代碼,只是知道的人還不多。
    (2)對于Firefox瀏覽器,直接調(diào)用eval函數(shù),則在調(diào)用者的空間執(zhí)行;如果調(diào)用       window.eval則在全局空間執(zhí)行。這個知道的人估計就更少了。畢竟alert(eval==window.eval)返回true!


以上就是javascript中eval函數(shù)的作用是什么,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學到更多知識。更多詳情敬請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI