傳 崋

做文艺女程序媛

【前端笔试题一(待续)】

   最近各大公司的实习招聘开始了,上学期的实习辞职到现在也快一个月了。这一月似乎没干什么似得,毕设开题也没弄,被老板抓着做实验,各种闹心的事。这月重新在看《JavaScript高级程序设计》,实习半年多都在做PHP,各种杂活,前端的知识本来就不好,更是忘了一大堆。笔试阿里的实习的时候,完全傻眼了。。。还是好好看看基础知识吧。最近有关注各个实习的笔试题,都是看完了然后就忘了,想想还是记录下来吧。为即将来临的找工作做做准备。

 

一、(function(){})();和(function(){}())每个括号的用途和区别。

      首先第一种形式是我们比较常见的,在闭包中我们会经常用的。称之为自执行匿名函数,也就是说我们创建了一个匿名函数,然后立即调用了它。

      先来看一个函数定义和函数表达式的区别:

    函数定义:function FunctionName([.....]){FunctionBody}

    函数表达式:function [FunctionName]([....]){FunctionBody}

  可以看到这两个形式非常的像,区别就是函数表达式可以省略函数名。在JS中,如果一条语句是以function 开始,那么就会被解释为函数定义,函数定义是不能紧跟着()被执行的。应该如下:

  var someFunction = function(){};  //定义函数

  someFunction();  //调用函数

  那么我们的匿名函数要怎样定义后立即调用执行呢。这就是我们见的第一种形式,在前面加个(function(){}),这里就会将函数定义转换成函数表达式,函数表达式就可以后面跟着圆括号立即执行了。

  好了,知道它的意思了,我们就可以很简单的知道各个括号的用途了。

  function();这个括号是函数的参数列表。

  (function(){});这个括号就是我们说的将一个函数定义转换为函数表达式。

  (function(){})();这个括号就是立即执行这个函数。因为JS没有块级作用域的概念,所以这个函数经常用来模仿块级作用域。函数体内的变量在函数执行完之后会立马被销毁掉。看个例子:  

function test(){
	for(var i = 0; i < 10; ++i){

	}
	alert(i);//10
}

  

function test(){
	(function(){
		for(var i = 0; i < 10; ++i){

		}
	})();
	alert(i);//Error:i is not defined!
}

  第二种写法其实和第一种写法最终效果是一样的,也是自执行匿名函数。这种是模块模式的写法。

二、How would you mark this work? add(2,5);//7  add(2)(5);//7

function add(a, b){
	var temp = function(b){
		return a + b;
	};

	if(typeof b == "undefined"){
		return temp;
	} else {
		return temp(b);
	}
}
console.log(add(2,5)); //7
console.log(add(2)(5));  //7

  

posted on 2015-04-16 12:04  傳崋  阅读(734)  评论(5编辑  收藏  举报