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

Javascript中Eval函數(shù)的使用說明

 更新時間:2008年10月11日 22:04:25   作者:  
JavaScript有許多小竅門來使編程更加容易。 其中之一就是eval()函數(shù),這個函數(shù)可以把一個字符串當(dāng)作一個JavaScript表達(dá)式一樣去執(zhí)行它。
舉個小例子:
復(fù)制代碼 代碼如下:

var the_unevaled_answer = "2 + 3";
var the_evaled_answer = eval("2 + 3");
alert("the un-evaled answer is " + the_unevaled_answer + " and the evaled answer is " + the_evaled_answer);

如果你運(yùn)行這段eval程序, 你將會看到在JavaScript里字符串"2 + 3"實(shí)際上被執(zhí)行了。
所以當(dāng)你把the_evaled_answer的值設(shè)成 eval("2 + 3")時, JavaScript將會明白并把2和3的和返回給the_evaled_answer。
這個看起來似乎有點(diǎn)傻,其實(shí)可以做出很有趣的事。比如使用eval你可以根據(jù)用戶的輸入直接創(chuàng)建函數(shù)。
這可以使程序根據(jù)時間或用戶輸入的不同而使程序本身發(fā)生變化,通過舉一反三,你可以獲得驚人的效果。
在實(shí)際中,eval很少被用到,但也許你見過有人使用eval來獲取難以索引的對象。
文檔對象模型(DOM)的問題之一是:有時你要獲取你要求的對象簡直就是痛苦。
例如,這里有一個函數(shù)詢問用戶要變換哪個圖象:變換哪個圖象你可以用下面這個函數(shù):
function swapOne()
{
var the_image = prompt("change parrot or cheese","");
var the_image_object;
if (the_image == "parrot")
{
the_image_object = window.document.parrot;
}
else
{
the_image_object = window.document.cheese;
}
the_image_object.src = "ant.gif";
}
連同這些image標(biāo)記:
[img src="/stuff3a/parrot.gif" name="parrot"]
[img src="/stuff3a/cheese.gif" name="cheese"]
請注意象這樣的幾行語句:
the_image_object = window.document.parrot;
它把一個圖象對象敷給了一個變量。雖然看起來有點(diǎn)兒奇怪,它在語法上卻毫無問題。
但當(dāng)你有100個而不是兩個圖象時怎么辦?你只好寫上一大堆的 if-then-else語句,要是能象這樣就好了:
function swapTwo()
{
var the_image = prompt("change parrot or cheese","");
window.document.the_image.src = "ant.gif";
}
不幸的是, JavaScript將會尋找名字叫 the_image而不是你所希望的"cheese"或者"parrot"的圖象,
于是你得到了錯誤信息:”沒聽說過一個名為the_image的對象”。
還好,eval能夠幫你得到你想要的對象。
function simpleSwap()
{
var the_image = prompt("change parrot or cheese","");
var the_image_name = "window.document." + the_image;
var the_image_object = eval(the_image_name);
the_image_object.src = "ant.gif";
}
如果用戶在提示框里填入"parrot",在第二行里創(chuàng)建了一個字符串即window.document.parrot. 然后包含了eval的第三
行意思是: "給我對象window.document.parrot" - 也就是你要的那個圖象對象。一旦你獲取了這個圖象對象,你可以把
它的src屬性設(shè)為ant.gif. 有點(diǎn)害怕?用不著。其實(shí)這相當(dāng)有用,人們也經(jīng)常使用它。
我們常常在Javascript中間到Eval這個函數(shù),
有些人覺得這個函數(shù)很奇怪,可以把一些字符串變的功能很強(qiáng)大
在我們需要將普通的字符串轉(zhuǎn)變成具體的對象的時候,就會用到這個函數(shù)
eval 函數(shù)對作為數(shù)字表達(dá)式的一個字符串進(jìn)行求值,其語法為:
eval(expr)
此處 expr 是一個被求值的字符串參數(shù)。如果該字符串是一個表達(dá)式,eval 求該表達(dá)式的值;如果該參數(shù)代表一個或多個 JavaScript 語句,那么 eval 執(zhí)行這些語句。eval 函數(shù)可以用來把一個日期從一種格式(總是字符串)轉(zhuǎn)換為數(shù)值表達(dá)式或數(shù)字。
==============================
Eval 函數(shù)
功能:先解釋Javascript代碼,然后在執(zhí)行它
用法:Eval(codeString)
codeString是包含有Javascript語句的字符串,在eval之后使用Javascript引擎編譯。
注釋:
例子:eval(id + "_icon.src="/imgs/collapse_up.gif'");
id是之前設(shè)定的參數(shù),而在雙引號中的字符串則是需要編譯的
引用:
復(fù)制代碼 代碼如下:

function tophide(id) //id indicates menu
{
if (top.topframeset.rows == "31,*")
{
top.topframeset.rows = "86,*";
eval(id + "_icon.src="/imgs/collapse_up.gif'");
eval(id + "_icon.alt='Collapse The Head'");
head.style.display = "block"
}
else
{
top.topframeset.rows = "31,*";
eval(id + "_icon.src="/imgs/collapse_down.gif'");
eval(id + "_icon.alt='Expand The Head'");
head.style.display = "none"
}
}

相關(guān)文章

  • webpack4從0搭建組件庫的實(shí)現(xiàn)

    webpack4從0搭建組件庫的實(shí)現(xiàn)

    這篇文章主要介紹了webpack4從0搭建組件庫的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • JavaScript中繼承用法實(shí)例分析

    JavaScript中繼承用法實(shí)例分析

    這篇文章主要介紹了JavaScript中繼承用法,以實(shí)例形式較為詳細(xì)的分析了javascript實(shí)現(xiàn)繼承的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • 簡單實(shí)現(xiàn)js選項(xiàng)卡切換效果

    簡單實(shí)現(xiàn)js選項(xiàng)卡切換效果

    這篇文章主要為大家詳細(xì)介紹了簡單實(shí)現(xiàn)js選項(xiàng)卡切換效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • CKeditor4 字體顏色功能配置方法教程

    CKeditor4 字體顏色功能配置方法教程

    這篇文章主要介紹了CKeditor4 字體顏色功能配置方法,結(jié)合圖文與實(shí)例的形式分析了CKeditor4 添加字體顏色擴(kuò)展功能的相關(guān)實(shí)現(xiàn)步驟與操作技巧,需要的朋友可以參考下
    2019-06-06
  • TypeScript中類型映射的使用

    TypeScript中類型映射的使用

    TypeScript中的映射類型和數(shù)學(xué)中的映射類似,能夠?qū)⒁粋€集合的元素轉(zhuǎn)換為新集合的元素,本文就來介紹一下TypeScript中類型映射的使用,感興趣的可以了解一下
    2023-10-10
  • js判斷傳入時間和當(dāng)前時間大小實(shí)例(超簡單)

    js判斷傳入時間和當(dāng)前時間大小實(shí)例(超簡單)

    下面小編就為大家分享一篇js判斷傳入時間和當(dāng)前時間大小實(shí)例(超簡單),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • 讓firefox支持IE的一些方法的javascript擴(kuò)展函數(shù)代碼

    讓firefox支持IE的一些方法的javascript擴(kuò)展函數(shù)代碼

    因?yàn)橐恍┐a,只能在IE下實(shí)現(xiàn),如果用firefox實(shí)現(xiàn)就必須用一些擴(kuò)展函數(shù)。
    2010-01-01
  • 微信小程序?qū)崿F(xiàn)聊天室

    微信小程序?qū)崿F(xiàn)聊天室

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)聊天室,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • 微信小程序?qū)崿F(xiàn)select下拉框

    微信小程序?qū)崿F(xiàn)select下拉框

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)select下拉框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JS中offset和勻速動畫詳解

    JS中offset和勻速動畫詳解

    這篇文章主要介紹了JavaScript動畫:offset和勻速動畫詳解(含輪播圖的實(shí)現(xiàn)),并把實(shí)現(xiàn)代碼做了分享,有興趣的朋友參考下。
    2018-02-02

最新評論