一到关于js函数的前端面试题引发的血案
生活随笔
收集整理的這篇文章主要介紹了
一到关于js函数的前端面试题引发的血案
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目如下:
1 f = function() { return true; }; 2 g = function() { return false; }; 3 (function() { 4 if (g() && [] == ![]) { 5 f = function f() { return false; }; 6 function g() { return true; } 7 } 8 })(); 9 alert(f()); // true or false ??看IE6、IE7、IE8與其它非IE下的不同?
1 var f = function foo(){ 2 return typeof foo; // "foo" is available in this inner scope 3 }; // `foo` is never visible "outside" 4 typeof foo; // "undefined" 5 f(); // "function"除IE6、7、8外,其它瀏覽器均顯示foo為undefined?
這是JScript的bugs,好像IE9的beta2中已經修復了?(尚未安裝過,有待證實)?
?
IE中有兩個“特性”?
1、函數聲明中的標識符允許包含.運算符,例如function window.onload() {}?
2、函數表達式中的標識符可以被函數外部訪問?var f = function g(){}; typeof g; // "function"
?
一些相關文章:?
《關于JS引擎對var與function預解析?》
《如何理解表達式中的具名函數》
《函數聲明與函數表達式》?
《命名函數表達式探秘》
《具名函數表達式》
看完這些資料,做這道題應該就很簡單了吧?
?
在IE6、7、8下面,代碼等價于:
1 f = function() { return true; }; 2 g = function() { return false; }; 3 (function() { 4 var f, g; 5 g = function() {return true;} 6 f = function() {return false;} 7 if (g()) { 8 f = f; 9 } 10 })(); 11 alert(f());在FF下的代碼等價于:
1 f = function() { return true; }; 2 g = function() { return false; }; 3 (function() { 4 if (g()) { 5 /**..*/ 6 } 7 })(); 8 alert(f());在Chrome下等價于:
1 f = function() { return true; }; 2 g = function() { return false; }; 3 (function() { 4 var g; 5 function g() { 6 return true; 7 } 8 if (g()) { 9 f = function f() { 10 return false; 11 } 12 } 13 })(); 14 alert(f());轉載于:https://www.cnblogs.com/leolai/archive/2012/06/08/2541838.html
總結
以上是生活随笔為你收集整理的一到关于js函数的前端面试题引发的血案的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 线性表的表示和实现方式之链式表示和实现
- 下一篇: 共享一个简单的 Javacript He