标签:
废话篇:
今天看到了javascript的原型链,各种指向,各种对象有木有,各种晕,各种混淆有木有。兼职是挑战个人脑经急转弯的极限啊。不过,最终这一难题还是被我攻克了,哇咔咔。现在就把这东西记下来,免得到时候又忘了就悲催了。。。。
正文篇:
function的定义方法,及function对象的理解。
在我大js中秉承着一切都是对象的原则,不论是方法还是其他都不例外。
我们在使用java的时候经常要编写方法,这时候其用的关键字是function,而在js中我们在编写函数的时候也是用这个关键字,所以常常会使我们错把两者进行关联,所以常常会吧我们引导只一个错误的方向。
所以接下来我们先从function的定义开始说起。
一:实际上就和我们最为平常的方法是一样的。
function fname(test){ alert(""+test); }
二:通过Function的函数的构造器进行函数对象的定义。
var fname = new Function("test", "alert(‘‘+test);"); 第一个参数实际上是表示要传入函数中的参数,二第二个参数表示的是当前的函数要执行的过程。两个参数实际上都是string类型的。但是又上可以看出实际上当前的内容是十分的繁杂。
三:通过变量只带一块function关键字定义的方法来进行定义。
var fname = function(test){alert(""+test);}
上面的三种方法虽然最后都是声明定义了一个函数,但是也是有区别的。第一种方法实际上是为函数命名为fname,而二三种方法使用起来实际上是把一个匿名函数赋值给一个变量。使用第二种方法来定义函数的时候,实际上就是调用构造函数并在每次解析的时候都会重新读取并创建一新的函数对象,由此可见当在循环体中调用这样的函数的时候会是十分的低效的,还有一点就是,当我们使用其创建一个函数对象的时候,其并不遵循典型的作用域,而是一直作为顶级函数来执行的。意思就是,当在函数内部调用它的时候,其实他并不会用函数内部定义的变量。而是只能使用全局变量。
第一三种方法实际上市定义了一种函数直接量。当我们不为函数直接量定义名称的时候。函数直接量就叫做匿名函数。那么我们如何调用一个匿名直接量,如下:
1、执行后得到返回值的函数调用
//方式一,调用函数,得到返回值。强制运算符使函数调用执行
(function(x,y){
alert(x+y);
return x+y;
}(3,4));
//方式二,调用函数,得到返回值。强制函数直接量执行再返回一个引用,引用在去调用执行
(function(x,y){
alert(x+y);
return x+y;
})(3,4);
2、执行后忽略返回值
//方式三,调用函数,忽略返回值
void function(x) {
x = x-1;
alert(x);
}(9);
嗯,最后看看错误的调用方式
//错误的调用方式
function(x,y){
alert(x+y);
return x+y;
}(3,4);
有点扯远了。实际上在使用第一和第三种的方法来说的话,在第一次解析的时候会通过new Function来定义一个函数的对象,并把这一对象作为内部对象来进行存储和运行。由此可知在js中没每写一个对象,实际上就是在其中存储一个相关的函数对象,并在我们需要调用的时候对其进行调用。
接下来我们来咯具体的了解一下分Function对象的定义和内容吧。
1.首先是我们最为常用的内容arguments对象。他的定义是,一个类似于数组的对象,对应的是传递给函数对象的属性。arguments对象是一个所有的函数内部都可以用的函数内部变量。当我们调用函数的时候,他会存储我们传输进来的参数的数据的。如下端的吗。
1 function test(){ 2 if(arguments[0]){ 3 alert("arguments:",+arguments[0]); 4 } 5 } 6 test("a");//当前页面中会显示出一个弹出框并显示arguments:a
所以由上面可以看出,arguments对象的使用方式和array是十分的相像的。为什么说他只是类似数组对象呢,因为他仅仅只有length属性但并没有array的其他属性和方法。
当然在arguments对象中也是有一些其自己的属性的,如下
当然对于函数对象js中也是有定义一些基本方法的。
function test(){ alert("" + this); } function testTwo(a){
console.log("this:"+this); console.log("a:"+a); } testTwo.apply(test, [1]); //输出的效果是this:function test(){ alert("" + this);} 与 a:1
实际上apply是用第一个参数中的对象替换当前的函数中的this指针,并用数组参数中的数据来来替换但钱的函数调用时的参数。
1 var displayArgs = function (val1, val2, val3, val4) { 2 document.write(val1 + " " + val2 + " " + val3 + " " + val4); 3 } 4 5 var emptyObject = {}; 6 7 var displayArgs2 = displayArgs.bind(emptyObject, 12, "a"); 8 9 displayArgs2("b", "c"); 10 11 // Output: 12 a b c
由上面可见实际上bind函数就有点像是绑定当前的内容和一个数据的关系。并返回一个一个可调用对象。
JS function的定义方法,及function对象的理解。
标签:
原文地址:http://www.cnblogs.com/pingchuanxin/p/5722139.html