前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >命名函数表达式

命名函数表达式

作者头像
meteoric
发布2018-11-15 16:00:22
4540
发布2018-11-15 16:00:22
举报
文章被收录于专栏:游戏杂谈

好文章,可惜中文译文已经无法访问了。不过在cssrain上找到一篇:www.cssrain.cn/demo/named%20function%20expression/Named%20function%20expressions%20demystified.htm

英文地址还在:kangax.github.com/nfe/

看IE6、IE7、IE8与其它非IE下的不同

代码语言:javascript
复制
 var f = function foo(){
    return typeof foo; // "foo" is available in this inner scope
  };
  // `foo` is never visible "outside"
  typeof foo; // "undefined"
  f(); // "function"

除IE6、7、8外,其它浏览器均显示foo为undefined

这是JScript的bugs,好像IE9的beta2中已经修复了?(尚未安装过,有待证实)

IE中有两个“特性”

1、函数声明中的标识符允许包含.运算符,例如

function window.onload() {}

2、函数表达式中的标识符可以被函数外部访问

代码语言:javascript
复制
var f = function g(){}; 
代码语言:javascript
复制
typeof g; // "function"
代码语言:javascript
复制
代码语言:javascript
复制
代码语言:javascript
复制
代码语言:javascript
复制
代码语言:javascript
复制
具名函数表达式,果真是篇好文章:

《Named function expressions demystified》

每周读一篇,思路更清晰^_^。

看完这些资料,做玉伯这道题应该就很简单了吧?

代码语言:javascript
复制
f = function() { return true; };
g = function() { return false; };

(function() {
    if (g() && [] == ![]) {
        f = function f() { return false; };
        function g() { return true; }
    }
})();

alert(f()); // true or false ?

我的答案是,在IE6、7、8下面,代码等价于:

代码语言:javascript
复制
<script type="text/javascript">
f = function() { return true; };
g = function() { return false; };


(function() {
	var f, g;

	 g = function() {return true;}
	 f = function() {return false;}

	if (g()) {
		f = f;
    }
})();

alert(f());
</script>

在FF下的代码等价于:

代码语言:javascript
复制
  <script type="text/javascript">
f = function() { return true; };
g = function() { return false; };


(function() {
	
	if (g()) {
        /**..*/
    }
})();

alert(f());
</script>

在Chrome下等价于:

代码语言:javascript
复制
<script type="text/javascript">
f = function() { return true; };
g = function() { return false; };


(function() {
	var g;

	function g() {
		return true;
	}

	if (g()) {	
	
       f = function f() {
			return false;
	   }

    }
})();

alert(f()); 
</script>

那么就来测试一下不同浏览器下的效果吧 ~ ~

<script type="text/javascript"> f = function() { return true; }; g = function() { return false; }; (function() { if (g() && [] == ![]) { alert(f); f = function f() { return false; }; function g() { return true; } } })(); alert(f()); // true or false ? </script>预览代码

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2010-10-08 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档