欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JS 面向对象学习笔记

程序员文章站 2022-07-04 08:26:48
...

JS 面向对象学习笔记,整理一下:

//arguments装载向函数的传参,类似数组
function add(){
	var res = 0;
	for(var i=0; i<arguments.length; i++){
		res += arguments[i];	
	}
	return res;
}

//alert(add(1,2));//3
//alert(add(1,2,3,4));//10


//call()与apply()函数的应用
var b1 = {v:'this is b1'};
var b2 = {v:'this is b2'};

function b(){
	alert(this.v);	
}

/*b();		//undifiend(this指代window)
window.b(); //undifiend(this指代window)
//call的第一个参数指代函数上下文(作用域)
b.call(b1); //this is b1(this指代b1)
b.apply(b2);//this is b2(this指代b2)*/


//类的修改【扩展】
var d = new Number(5);
d.add = function(b){
	//return this+b;	
	return this+arguments[0];
}

//alert(d.add);
//alert(d.add(6));


//如何给所有的Number的实例都加上一个add方法
//prototype属性,所有的类均具有
//给Number类的prototype属性加了一个方法,这个方法可以应用与所有的Number实例
Number.prototype.add = function(b){
	return this+b;	
}
var c = 111;
//链式语法
//alert(c.add(100).add(200).add(300));//711


//给Array类扩展一个indexOf方法
Array.prototype.indexOf = function(v){
	for(var i=0; i<this.length; i++){
		if(this[i] == v){
			return i;
		}
	}
	return -1;
}

var ii = ['11', '22'];
//alert(ii.indexOf('22')); //1


//javascript 类
function Animal(name){
	var dd = 1;//私有变量
	this.name = name; //公有变量
	this.age = 0;
	//定义私有方法
	function prMethod(){
		return dd;
	}
	//定义特权方法,可以访问私有、公有所有成员(变量dd不可销毁,闭包)
	this.sayHello = function(){
		dd++;
		var res = prMethod();
		return dd+':'+this.name+':'+this.age+':'+res;
	}
}
	
var i1 = new Animal('cat'); 
var i2 = new Animal('dog'); 

//alert(i1.sayHello()); //2:cat:0:2
//alert(i2.sayHello()); //2:dog:0:2

//此类扩展方法只能访问类的公有成员
Animal.prototype.hello = function(){
	return this.name+':'+this.age;
}

//alert(i1.hello()); //cat:0
//alert(i2.hello()); //dog:0


//继承的实现
function classA(name){
	this.name = name;
	this.showName = function(){
		return this.name;
	}
}

//类B继承类A
function classB(name){
	//继承方法一
	/*this.bMethod = classA;
	this.bMethod(name);
	delete this.bMethod;*/
	
	//执行classA函数,并将它的上下文【作用域】指向this(即为classB的实例)
	//继承方法二
	//classA.call(this, name);
	
	//继承方法三
	classA.apply(this, [name]);
}
var aa = new classA('aa');
var bb = new classB('bb');
//alert(aa.showName()); //aa
//alert(bb.showName()); //bb

//继承方法四
function classC(){
}

classC.prototype = new classB('bb1');
var cc = new classC();
cc.name = 'cc';
//alert(cc.showName()); //cc
相关标签: JS oo