使用new Function( ) 來進行語法檢查
eval( ) 方法是不能亂用的,在不適當的時候使用eval( ) 方法可能導致整個程序都會出問題的;
而new Function( ) 就沒這麼大問題。雖然new Function( ) 在任何情況下,構造的函數都是在全局作用域下直接工作的,但只作語法檢查的話,並不會因為作用域問題而產生意外結果,只要你不直接調用通過它構造的新函數。
在eval( ) 接受的參數前面增加“0,”
其實這是由於IE中存在一個bug。出於某種原因,如果你在IE 中想通過調用eval( ) 來動態地構造一個函數。
例如:
eval('(function(){ /* code here */ })');
在IE 中得到的返回將是undefined,而其它浏覽器則會正確地返回這個新構造的函數的引用。
最簡單有效的解決辦法是:在前邊加上“0,”,這樣就能在所有主流浏覽器中兼容。
例如:
eval('0,function(){ /* code here */ }');
注:在IE9 的Chakra 引擎中,這個問題已經解決。
使用數組對象的concat方法來產生新數組
把單個對象參數轉化為只包含一個元素的數組再來處理,可以使用“[ ].concat(o)”的形式。
例如:
復制代碼 代碼如下:
var arr1 = [1,2];
var arr2 = [3,4];
var arr3 = arr1.concat(arr2);
alert(arr3.length);
另一種方式是:if (!(o instanceof Array)) o = [o];
// 和ECMAScript 5 中的isArray 相比不夠嚴謹。
網友回復:
1.eval 確實不能亂用;
2.在IE eval 的時候,我的解決方法是在執行函數體內return ;
3.Array.prototype.concat.apply([1,2,3],[4,5,6]);