javascript 面向对象基础

可变参数:

    	//javascript 可变参数 
    	function sum(){
    		var s=0;
    		for(var i=0; i<arguments.length; i++){
    			s+=arguments[i];
    		}
    		return s;
    	}
    	
    	alert(sum(1,2));//3
    	alert(sum(1,2,3));//6

使用Function类创建函数:

说明:所有的参数都必须是字符串型的,最后的参数必须是这个动态函数的功能程序代码。
<script language="javascript">
	var square = new Function ("x","y",
			"var sum;sum= x*x + y*y;return sum;");
	alert(square(3,2));
     var alsoDoSquare  = doAdd;
    alert(alsoDoSquare (3,2));
</script>

查看对象的类型:
alert(typeof s1);
//访问一个对象的构造函数,使用constructor
alert(typeof d1=="object" && d1.constructor==Dog);
闭包(closure)
Javascript闭包就是在另一个作用域中保存了一份它从上一级函数或作用域取得的变量(键值对),而这些键值对是不会随上一级函数的执行完成而销毁。
这样在执行完var c=a()后,变量c实际上是指向了函数b,b中用到了变量i,再执行c()后就会弹出一个窗口显示i的值(第一次为1)。这段代码其实就创建了一个闭包,为什么?因为函数a外的变量c引用了函数a内的函数b,就是说:

当函数a的内部函数b被函数a外的一个变量引用的时候,就创建了一个我们通常所谓的“闭包”。
   function a() {   
    var i = 0;   
    function b() {   
     alert(++i);   
   }   
    return b;   
    }   
    var c = a();   
    c();  
闭包的作用就是在a执行完并返回后,闭包使得Javascript的垃圾回收机制GC不会收回a所占用的资源,因为a的内部函数b的执行需要依赖a中的变量。
 
函数的作用域及this
 词法作用域(lexcical scope)。通俗地讲,就是javascript变量的作用域是在定义时决定而不是执行时决定,也就是说词法作用域取决于源码,编译器通过静态分析就能确定,因此词法作用域也叫做静态作用域(static scope)。但需要注意,with和eval的语义无法仅通过静态技术实现,所以只能说javascript的作用域机制非常接近词法作用域(lexical scope).
javascript引擎在执行每个函数实例时,都会创建一个执行环境(execution context)。执行环境中包含一个调用对象(call object)
调用对象是一个scriptObject结构(scriptObject是与函数相关的一套静态系统,与函数实例的生命周期保持一致),用来保存内部变量表varDecls、内嵌函数表funDecls、父级引用列表 upvalue等语法分析结构(注意varDecls和funDecls等信息是在语法分析阶段就已经得到,并保存在语法树中。函数实例执行时,会将这些信息从语法树复制到scriptObject上)。

apply and call:它们的作用都是将函数绑定到另外一个对象上去运行,两者仅在定义参数方式有所区别:
apply(thisArg,argArray);
call(thisArg[,arg1,arg2…] ]);
即所有函数内部的this指针都会被赋值为thisArg,这可实现将函数作为另外一个对象的方法运行的目的。
b(){//调用this}//这里的this是指向windows
b(b1){//调用this}//this指向b1




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值