eval() 是個滿好用的函式,用途也多種。但會有資安上的疑慮。不建議使用。
eval 是 evaluates 。例如:
Javascript
1 | var n=1; |
上面結果會變成 a1=b*c ,就是變數 a1 的結果為 6。
由以上可知,eval() 是把一組字串,當作指令來執行,並得出結果。
實作時,在訂單處理上應用較廣,例如以下是份簡單訂單:
數量 | 單價 | 小計 |
---|---|---|
Q1 | P1 | T1 |
Q2 | P2 | T2 |
Q3 | P3 | T3 |
用編號來進行不同筆數訂單欄位命名,而不是每個欄位獨立命名,顯示,在輸入數量及單價後,小計要能自動計算。
假設這份表單名為 order,所以:
document.order.T1.value=document.order.Q1.value*document.order.P1.value;
document.order.T2.value=document.order.Q2.value*document.order.P2.value;
document.order.T3.value=document.order.Q3.value*document.order.P3.value;
你是不是會想用 for 來跑迴圈?可是,T1、;Q1 這些欄位名稱一直在變,怎麼跑迴圈呢?這時,eval() 就派上用場了,eval() 把「唸的內容」當結果執行,這個例子怎麼唸呢?
「第一個 T 的值等於第一個 Q 的值乘以第一個 P 的值」,換成
Javascript
1 | eval(): |
把 eval() 裡的字串,i 的值分別用 1,2,3 套入,結果和前面寫一大串三行的效果一模一樣。