var s='global'; function demo3(){ X2.Eval('var s="local"'); } demo3(); alert(s); //->'local'
可見,在demo3函數內重新定義了全局變量s="local"。 需要注意的是X2.Eval并不返回值,如果要進行表達式的求值,還是用系統的eval函數。X2.Eval設計為僅做全局代碼定義用。 其實看到這里,或許有人感覺問題也太容易解決了點,呵呵,但發現這個辦法倒是需要些運氣和技巧的: (1)對于IE瀏覽器,默認已經提供了這樣的函數:execScript,用于在全局空間執行代碼,只是知道的人還不多。 (2)對于Firefox瀏覽器,直接調用eval函數,則在調用者的空間執行;如果調用 window.eval則在全局空間執行。這個知道的人估計就更少了。畢竟alert(eval==window.eval)返回true! Firefox的eval函數的特點的確是很令人奇怪的,但從javascript規范中倒也能找到其來源: If value of the eval property is used in any way other than a direct call (that is, other than by the explicit use of its name as an Identifier which is the MemberExpression in a CallExpression), or if the eval property is assigned to, an EvalError exception may be thrown. 意思大概就是說eval函數的執行是和調用者相關的,但并沒有說其執行上下文的問題。所以IE和Firefox孰是孰非也就很難說了,大家知道解決辦法就好。