一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

Javascript中eval函數的使用方法與示例

定義和用法 eval() 函數可計算某個字符串,并執行其中的的 JavaScript 代碼。

語法 eval(string) 參數 描述 string 必需。要計算的字符串,其中含有要計算的 JavaScript 表達式或要執行的語句。 返回值 通過計算 string 得到的值(如果有的話)。

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

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

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

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

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

提示和注釋 提示:雖然 eval() 的功能非常強大,但在實際使用中用到它的情況并不多。

下面為大家分享一個常用的小例子:

<SCRIPT language="Javascript">function showsubmenu(sid){whichEl = eval("submenu" + sid);if (whichEl.style.display == "none"){eval("submenu" + sid + ".style.display=/"/";");}else{eval("submenu" + sid + ".style.display=/"none/";");}}</SCRIPT>

Eval 函數

功能:先解釋Javascript代碼,然后在執行它

用法:Eval(codeString)

codeString是包含有Javascript語句的字符串,在eval之后使用Javascript引擎編譯。 
舉個小例子:

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);

如果你運行這段eval程序, 你將會看到在JavaScript里字符串"2 + 3"實際上被執行了。所以當你把the_evaled_answer的值設成 eval("2 + 3")時, JavaScript將會明白并把2和3的和返回給the_evaled_answer。 

這個看起來似乎有點傻,其實可以做出很有趣的事。比如使用eval你可以根據用戶的輸入直接創建函數。這可以使程序根據時間或用戶輸入的不同而使程序本身發生變化,通過舉一反

三,你可以獲得驚人的效果。

在實際中,eval很少被用到,但也許你見過有人使用eval來獲取難以索引的對象。 文檔對象模型(DOM)的問題之一是:有時你要獲取你要求的對象簡直就是痛苦。例如,這里有一個函數詢問用戶要變換哪個圖象:變換哪個圖象你可以用下面這個函數:

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標記:

<img src="/stuff3a/parrot.gif" name="parrot" />
<img src="/stuff3a/cheese.gif" name="cheese">

請注意象這樣的幾行語句:
the_image_object = window.document.parrot;
它把一個圖象對象敷給了一個變量。雖然看起來有點兒奇怪,它在語法上卻毫無問題。但當你有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",在第二行里創建了一個字符串即window.document.parrot. 然后包含了eval的第三行意思是: "給我對象window.document.parrot" - 也就是你要的那個圖象對象。一旦你獲取了這個圖象對象,你可以把它的src屬性設為ant.gif. 有點害怕?用不著。其實這相當有用,人們也經常使用它。

JavaScript技術Javascript中eval函數的使用方法與示例,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 在线看黄网站 | 一区二区三区视频在线播放 | 亚洲国产精品日韩一线满 | 一区二区三区成人 | 久久亚洲一级α片 | 亚洲国产成人久久精品动漫 | 牛牛碰在线视频 | 一区二区高清视频 | 亚洲激情另类 | 日本加勒比网站 | 日韩福利影视 | 黄色片网站在线免费观看 | 色偷偷资源 | 国产成人高清视频 | 一区二区三区在线免费视频 | 久久在精品线影院精品国产 | 99久久国产综合精麻豆 | 国产第1页| 成年美女黄网站色 | 91精品观看91久久久久久 | 亚洲第一页国产 | 91精品福利在线观看 | 一区二区三区四区视频 | 色哟哟导航 | 色综合天天综合中文网 | 97午夜视频 | 国产综合色在线视频区 | 91av免费| 色视频在线观看网站 | 怡红院精品视频 | 最新91| 人人干在线观看 | 亚洲乱码一二三四区乱码 | 精品国产系列在线观看 | 五月婷婷开心网 | 亚欧三级| 亚洲国产青草 | 欧美一级亚洲一级 | 狠狠做五月深爱婷婷天天综合 | 伊人色综合久久天天 | 亚洲一卡2卡4卡5卡6卡在线99 |