小編給大家分享一下JavaScript中eval()函數(shù)怎么用,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)公司主要從事做網(wǎng)站、成都網(wǎng)站制作、網(wǎng)頁設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)黃陂,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18982081108
調(diào)用eval函數(shù),可以將其參數(shù)作為javascript程序進(jìn)行解釋。換句話說,eval可以把它的參數(shù)當(dāng)做代碼
來執(zhí)行。
function f(x) { eval('var y=x'); console.log('y:', y); } f('hello');//y:hello
在這個(gè)例子中,eval
將它的string
參數(shù)var y=x
作為一行代碼執(zhí)行了,在函數(shù)f
內(nèi)部聲明了一個(gè)局部變量y
。這和
function f(x) { var y=x; console.log('y:', y); } f('hello');//y:hello
的執(zhí)行效果基本相同。
允許eval函數(shù)干擾作用域,是一個(gè)相當(dāng)錯(cuò)誤的做法。這種做法會(huì)使一段代碼變得難以理解,并且不再安全。下面這個(gè)例子便賦予了外部調(diào)用者修改局部變量,改變局部作用域的能力。
例子
let g = '全局變量' function f(src) { eval(src); console.log('g:', g); } //以上為源代碼 f("var g= '局部變量'");//g:局部變量 f("var y= '局部變量'");//g:全局變量
當(dāng)我們把一個(gè)沒有在源代碼中定義的變量y
,傳入eval
函數(shù)時(shí),這段代碼執(zhí)行的結(jié)果將變得難以預(yù)測。
保證eval
函數(shù)不影響外部作用域的一個(gè)簡單方法是使用嵌套的作用域。ES5的嚴(yán)格模式
便是這樣做的。
例子
let g = '全局變量' function f(src) { (()=> eval(src))();//在嵌套作用域中執(zhí)行eval console.log('g:', g); } //以上為源代碼 f("var g= '局部變量'");//g:全局變量 f("var y= '局部變量'");//g:全局變量
當(dāng)函數(shù)調(diào)用涉及eval
標(biāo)識(shí)符時(shí),可以稱為直接調(diào)用。此時(shí),被執(zhí)行的程序(eval的參數(shù))具有完全訪問調(diào)用者局部作用域的權(quán)限。
例子
const g = '全局變量'; function foo() { const g = '局部變量'; console.log(eval('g'));//直接調(diào)用,可以訪問到foo的局部作用域,所以輸出的是局部變量g } foo(); //局部變量
綁定eval
到另一個(gè)變量名,在通過該變量調(diào)用eval
,稱之為間接調(diào)用。此時(shí),被執(zhí)行的程序(eval的參數(shù))失去對局部作用域的訪問能力。利用逗號操作符,
,可以實(shí)現(xiàn)間接調(diào)用的簡潔寫法。
例子
const g = '全局變量'; function foo2() { const g = '局部變量'; cont test = eval; //間接調(diào)用,不能訪問函數(shù)內(nèi)部的變量g console.log(test('g')); //全局變量 //間接調(diào)用簡潔方式 console.log((0, eval)('g'));//全局變量 }
以上是“JavaScript中eval()函數(shù)怎么用”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享題目:JavaScript中eval()函數(shù)怎么用
文章來源:http://jinyejixie.com/article22/ghodcc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、標(biāo)簽優(yōu)化、定制開發(fā)、網(wǎng)站策劃、網(wǎng)站排名、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)