posts - 73,  comments - 55,  trackbacks - 0

          等你需要動態(tài)創(chuàng)建語句的時候,你將會發(fā)現(xiàn)它非常獨特的作用,上網(wǎng)看了半天,找到些零散的內(nèi)容,想來也算非常全面的了,全部把它收集起來放在這里以備后用,也供大家討論學習使用。

          【eval()函數(shù)】

          JavaScript有許多小竅門來使編程更加容易。
          其中之一就是eval()函數(shù),這個函數(shù)可以把一個字符串當作一個JavaScript表達式一樣去執(zhí)行它。
          舉個小例子:

          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"實際上被執(zhí)行了。
          所以當你把the_evaled_answer的值設(shè)成 eval("2 + 3")時, JavaScript將會明白并把2和3的和返回給the_evaled_answer。
          這個看起來似乎有點傻,其實可以做出很有趣的事。比如使用eval你可以根據(jù)用戶的輸入直接創(chuàng)建函數(shù)。
          這可以使程序根據(jù)時間或用戶輸入的不同而使程序本身發(fā)生變化,通過舉一反三,你可以獲得驚人的效果。
          在實際中,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標記:

          [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",在第二行里創(chuàng)建了一個字符串即window.document.parrot. 然后包含了eval的第三
          行意思是: "給我對象window.document.parrot" - 也就是你要的那個圖象對象。一旦你獲取了這個圖象對象,你可以把
          它的src屬性設(shè)為ant.gif. 有點害怕?用不著。其實這相當有用,人們也經(jīng)常使用它。

          我們常常在Javascript中間到Eval這個函數(shù),
          有些人覺得這個函數(shù)很奇怪,可以把一些字符串變的功能很強大
          在我們需要將普通的字符串轉(zhuǎn)變成具體的對象的時候,就會用到這個函數(shù)

          eval 函數(shù)對作為數(shù)字表達式的一個字符串進行求值,其語法為:

          eval(expr)

          此處 expr 是一個被求值的字符串參數(shù)。如果該字符串是一個表達式,eval 求該表達式的值;如果該參數(shù)代表一個或多個 JavaScript 語句,那么 eval 執(zhí)行這些語句。eval 函數(shù)可以用來把一個日期從一種格式(總是字符串)轉(zhuǎn)換為數(shù)值表達式或數(shù)字。

          ==============================
          Eval 函數(shù)
          功能:先解釋Javascript代碼,然后在執(zhí)行它
          用法:Eval(codeString)
          codeString是包含有Javascript語句的字符串,在eval之后使用Javascript引擎編譯。

          注釋:

          例子:eval(id + "_icon.src="/imgs/collapse_up.gif'");
          id是之前設(shè)定的參數(shù),而在雙引號中的字符串則是需要編譯的

          引用:
          --------------------------------------------------------------------------------
          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"
          ??? }
          }

          posted on 2006-06-13 15:04 保爾任 閱讀(194) 評論(0)  編輯  收藏

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           

          <2025年7月>
          293012345
          6789101112
          13141516171819
          20212223242526
          272829303112
          3456789

          常用鏈接

          留言簿(4)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 平江县| 望都县| 阿坝县| 磐石市| 泾川县| 井研县| 宕昌县| 武山县| 应城市| 桂阳县| 沐川县| 宁安市| 淮南市| 长海县| 绍兴市| 中超| 长乐市| 新建县| 象山县| 宜春市| 方山县| 甘孜| 潮州市| 舒兰市| 永丰县| 卓尼县| 德兴市| 泽库县| 开封市| 民和| 昌邑市| 两当县| 金门县| 防城港市| 大城县| 郧西县| 龙陵县| 太原市| 临猗县| 卢湾区| 靖西县|