52AV手機A片王|52AV.ONE
標題: Javascript 內建的eval()語法 [打印本頁]
作者: media 時間: 2014-12-3 22:00
標題: Javascript 內建的eval()語法
本帖最後由 media 於 2014-12-3 22:31 編輯 f9 m* }0 r6 D( o
" y( E% e! d, X* {5 E5 O% \eval() 是一個相當有趣、強大、不容易理解的函式,但功用實在太強,撰寫 Javascript 時經常會使用到。
eval 是 evaluates 的簡寫,是用來將「一句話」執出來。例如:
var n=3;4 e* a7 h- l+ t6 D. W& f4 W
var b=5,c=6;
3 e, ^) M" k- m! u! v5 h9 oeval('a'+n+'=b*c');
8 E- t+ t& N! ~
上例,在 eval() 中的字串,展開變成
% R6 b, P; ~! ?) m" A& K1 d/ D
沒錯,結果就是 a3=b*c,也就是變數 a3 的結果為 30。
由上例可知,eval() 是把一串字串,當作指令來執行,並得出結果,實作時,在訂單處理上應用較廣,例如以下是份簡單訂單:
7 W- u! T5 L( h7 F. v, W7 s
| 數量 | 單價 | 小計 |
| Q1 | P1 | T1 |
| Q2 | P2 | T2 |
| Q3 | P3 | T3 |
# q: V7 r {2 V' r
很基本的訂單,欄位後是欄位名稱,我想大多數設計師,都會像這個例子,用編號來進行不同筆數訂單欄位命名,而不是每個欄位獨立命名,顯示,在輸入數量及單價後,小計要能自動計算,也就是:
T1=Q1*P1 、 T2=Q2*P2 以及 T3=Q3*P3
假設這份表單名為 order,所以:
document.order.T1.value=document.order.Q1.value*document.order.P1.value;8 `. K6 a7 N: S$ S3 T& h3 |
document.order.T2.value=document.order.Q2.value*document.order.P2.value;1 L0 i1 {0 G5 ~2 ^
document.order.T3.value=document.order.Q3.value*document.order.P3.value;
/ Q7 O3 D$ d! p! K) C你是不是會想用 for 來跑迴圈?可是,T1、;Q1 這些欄位名稱一直在變,怎麼跑迴圈呢?這時,eval() 就派上用場了,eval() 把「唸的內容」當結果執行,這個例子怎麼唸呢?
「第一個 T 的值等於第一個 Q 的值乘以第一個 P 的值」,換成 eval():
var form=document.order;9 x% K" d7 d2 w H
for (var i=1;i<=3;i++){5 ?; X7 \2 e2 c0 W$ j3 E" b, F
eval('form.T'+i+'.value=form.Q'+i+'.value(form.P'+i+'.value');; R: \4 m7 j- ~5 A4 ]
}
" F0 h, C3 |; k: ]2 P, n把 eval() 裡的字串,i 的值分別用 1,2,3 套入,結果和前面寫一大串三行的效果一模一樣。
不錯用吧!
/ r- I& h; K) W3 b9 K9 `: |3 F1 Q
" ^. j$ F; G6 ~ `2 x# T! k! \
| 歡迎光臨 52AV手機A片王|52AV.ONE (https://www.52av.one/) |
Powered by Discuz! X3.2 |