先看看JS的一個函數
JavaScript eval() 函數
定義和用法
eval() 函數可計算某個字串,並執行其中的 JavaScript 程式碼。
語法
eval(string)
參數 描述
string 必需。要計算的字串,其中包含要計算的 JavaScript 表達式或要執行的語句。
傳回值
透過計算 string 得到的值(如果有的話)。
說明
該方法只接受原始字串作為參數,如果 string 參數不是原始字串,那麼該方法將不作任何改變地傳回。因此請不要為 eval() 函數傳遞 String 物件作為參數。
如果試圖覆寫 eval 屬性或把 eval() 方法賦予另一個屬性,並透過該屬性呼叫它,則 ECMAScript 實作允許拋出一個 EvalError 例外。
拋出
如果參數中沒有合法的表達式和語句,則拋出 SyntaxError 異常。
如果非法呼叫 eval(),則拋出 EvalError 異常。
如果傳遞給 eval() 的 Javascript 程式碼產生了一個異常,eval() 將把該異常傳遞給呼叫者。
提示與註解
提示:雖然 eval() 的功能非常強大,但在實際使用中用到它的情況並不多。
實例
範例1
在本例中,我們將在幾個字串上運用eval(),並看看傳回的結果:
輸出:
200
4
27
>
例子2
看一下在其他情況中,eval() 返回的結果:
程式碼如下:
eval("2 3") // 回傳5
var myeval = eval; // 可能會拋出EvalError 異常
myeval("2 3" ); // 可能會拋出EvalError 異常
可以使用下面這段程式碼來偵測eval() 的參數是否合法:
程式碼如下:
try {
alert("Result:" eval(prompt("Enter an expression:","")))) ;
}
catch(exception) {
alert(exception);
}
第一個方法就是使用js裡面的eval
以下是自己寫的例子
程式碼如下:
程式碼如下:
call("> showmsg");
function call(functionName){
eval("this." functionName "()");
}
function showmsg(){
alert(" success");
}
eval能將你拼接的字串自動辨識為方法,並且呼叫。
但弊端也是很大的,想像一下,某個人改你調用地方的方法名,便能調用你的任意方法。
複製程式碼
程式碼如下:
function call(functionName) {
showmsgs["showmsg"]();
}
showmsgs["showmsg"]();
}
var showmsgs = { showmsg: function () { alert("success"); } } call("showmsg");