本帖最後由 media 於 2014-12-3 22:31 編輯
' M; }/ w; t: r* ^3 C. v% g
. N/ V5 }- f+ a- u/ l6 E- @1 ~eval() 是一個相當有趣、強大、不容易理解的函式,但功用實在太強,撰寫 Javascript 時經常會使用到。 eval 是 evaluates 的簡寫,是用來將「一句話」執出來。例如: var n=3;* G+ \2 j: G/ u3 ?0 }( H) F: z
var b=5,c=6;
4 O7 E# g) Z2 ?9 j3 i2 Zeval('a'+n+'=b*c');
d1 U$ t& y; ^# Q) Q K+ i) A4 s: z上例,在 eval() 中的字串,展開變成 沒錯,結果就是 a3=b*c,也就是變數 a3 的結果為 30。 由上例可知,eval() 是把一串字串,當作指令來執行,並得出結果,實作時,在訂單處理上應用較廣,例如以下是份簡單訂單: % i9 i5 L2 |. ]: u x
| 數量 | 單價 | 小計 | | Q1 | P1 | T1 | | Q2 | P2 | T2 | | Q3 | P3 | T3 | $ B( ^/ H2 I6 @( f( C0 ~# a$ b8 O
很基本的訂單,欄位後是欄位名稱,我想大多數設計師,都會像這個例子,用編號來進行不同筆數訂單欄位命名,而不是每個欄位獨立命名,顯示,在輸入數量及單價後,小計要能自動計算,也就是: T1=Q1*P1 、 T2=Q2*P2 以及 T3=Q3*P3 假設這份表單名為 order,所以: document.order.T1.value=document.order.Q1.value*document.order.P1.value;( v6 N3 l4 B0 T% r6 u0 l( f
document.order.T2.value=document.order.Q2.value*document.order.P2.value;
4 s7 P$ Y% \: C- G6 S% Qdocument.order.T3.value=document.order.Q3.value*document.order.P3.value; ! d2 {- m& B, b
你是不是會想用 for 來跑迴圈?可是,T1、;Q1 這些欄位名稱一直在變,怎麼跑迴圈呢?這時,eval() 就派上用場了,eval() 把「唸的內容」當結果執行,這個例子怎麼唸呢? 「第一個 T 的值等於第一個 Q 的值乘以第一個 P 的值」,換成 eval(): var form=document.order;
6 X7 M9 y+ E' F9 T8 t+ i/ Zfor (var i=1;i<=3;i++){3 Q) {. H* A3 Z) ~$ N3 L- A6 p
eval('form.T'+i+'.value=form.Q'+i+'.value(form.P'+i+'.value');0 R4 _) Z! A& @6 ~, ^1 q( H. U/ z
}
4 V1 H& P, Z4 F$ C2 [1 s3 F把 eval() 裡的字串,i 的值分別用 1,2,3 套入,結果和前面寫一大串三行的效果一模一樣。 不錯用吧!
7 Y/ K& f5 R6 j$ w( u% Y/ u" l
9 c- E' ^9 y% c+ ?' ? |