js继承相关

这几天看到一篇文章详解Javascript的继承实现,发现js还是很深奥的,比如call、apply、prototype这些,问起来我也能说的头头是道的,但是看到一些复杂的代码有的时候还是会迷糊,所以查了好多资料,希望下次我也能用在代码中,写出优秀的代码,大神,我来了,哈哈哈哈哈......

1.call apply

func.call(newObj,arg1,arg2);

func.apply(newObj,[arg1,arg2]);

ecma中为了实现继承机制中的对象冒充,加入了call()和apply()两个方法。以call为例,call方法需要传入两个参数,第一个参数是this的值,第二个参数是传递给this指代的函数的值,为了改变函数内部的this指向,将函数的上下文改变为制定的新对象newObj。

function sayColor(sPrefix,sSuffix) {
    alert(sPrefix + this.color + sSuffix);
};

var obj = new Object();
obj.color = "blue";
//改变sayColor中this的指向为obj,将sayColor作为obj的一个方法。
sayColor.call(obj, "The color is ", "a very nice color indeed.");

2.this.init.apply(this, arguments)

看代码的时候,发现有这么一段代码,init是定义中构造函数原型链上的方法,这里的两个this指向构造函数实例化之后的对象,这句代码的意思是当满足条件判断的时候,实例化之后的对象就会执行init方法进行初始化,并且传入arguments参数(arguments中的参数必须与init方法中的参数相匹配)。

3.Object.prototype.hasOwnProperty()

官方解释是看某个对象是否含有指定的自身属性。所有继承了prototype属性的对象都会从原型链上继承到 hasOwnProperty 方法,该方法会忽略掉那些从原型链上继承到的属性。

copy方法遍历原型链上各个方法,赋值并返回该对象。

4.对象引用

看到这样一句话,以下为引用部分

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

//用来复制父类原型,由于父类原型上约定只写实例方法,所以复制的时候不必担心引用的问题
var copy = function (source) {
    var target = {};
    for (var i in source) {
        if (source.hasOwnProperty(i)) {
            target[i] = source[i];
        }
    }
    return target;
}///////////////////////////////////////////////////////////////////////////////////////////////////////////////////不明白为什么,只复制实例方法不必担心引用的问题,查资料后发现,引用是一个非常深奥的问题。希望以后能深入了解。5.this.base()为了实现在每个实例方法里,都能通过this.base()调用父类原型上相应的方法,该方法实现调用了一个匿名函数中返回的函数。

this.base()这个方法是通过一个匿名函数实现的,可以看到匿名函数实现的代码可读性非常强,代码结构也是很清晰的。

以下是它的经典实例。

//不使用立即执行函数表达式,在鼠标点击事件开始前,for循环已经完成
每次点击结果都为li集合的索引最大值
var li=document.getElementsByTagName(‘li‘);
for (var i=0; i<li.length; i++) {
 //将当前的i作为参数传入匿名函数,将i的值保存在内存中,
  (function(i){
        li[i].onclick = function () {
            console.log(i);
        };
   })(i);
}
//或者以下写法
var li=document.getElementsByTagName(‘li‘);
for (var i=0; i<li.length; i++) {
 //将当前的i作为参数传入匿名函数,将i的值保存在内存中,
    li[i].onclick = function (i) {
        return function(){
              console.log(i);
        }
    }(i);
}
        

匿名函数又叫立即执行函数表达式(Immediately-Invoked Function Expression (IIFE)),写法如下:

//多种写法
//第一种写法外面加个括号,原因是如果代码量很大,我们需要滚动到最底部去判断i是个function还是function的返回值。
var i = (function(){//代码}())
var i = (function(){//代码})()

闭包的定义是有权访问另一个作用域中的变量的函数,匿名函数也是这样的原理,匿名函数的第二个括号里面的参数传入参数,使得函数能够引用外部函数的变量,基于这个原理,我们能保存变量的状态。想了解匿名函数执行原理以及匿名函数作用域的,可看下JS----匿名函数这篇文章,我从中学到了很多,多谢园子里的大神们!

再回到javascript的继承实现,再看这个函数就很好理解了。

子类原型链的init方法用()括起来,里面是一个匿名函数,匿名函数传入两个参数(init和func),如果实例有base属性,就把它赋值给old变量。再把实例的base属性指向父类原型的init方法,func函数内部就可以通过this.base调用父类原型的方法。

小结:

javascript是一门深奥的语言,到了某个阶段会发现懂得的东西都只是皮毛,希望通过大神的指引能很快渡过这段时间,也希望我尽快减肥成功!

参考文章

1.【优雅代码】深入浅出 妙用Javascript中apply、call、bind

2.解析 this.initialize.apply(this, arguments)

3.js 对象深复制,创建对象和继承

4.js 匿名函数 闭包

5.JS----匿名函数

6.详解javascript立即执行函数表达式(IIFE)

时间: 2025-01-02 07:48:40

js继承相关的相关文章

[技术学习]js继承

今天又看了一遍js的面向对象方面的知识,重点看了继承相关内容,已经记不得看了第几次这个内容,终于觉得自己好像懂了,特记录下来过程. js面向对象继承分为两大类,主要分为对象继承和非对象继承(拷贝继承),这次主要谈对象继承.对象继承主要有两种:原型继承和对象冒充继承. 一.原型继承,将子类的原型引用父类的实例,从而达到将子类的原型与父类的原型和父类的构造函数关联起来的目的. function Person(name){ this.name=name; } Person.prototype.sayN

js继承的常用方式

写在前面的话:这篇博客不适合对面向对象一无所知的人,如果你连_proto_.prototype...都不是很了解的话,建议还是先去了解一下JavaScript面向对象的基础知识,毕竟胖子不是一口吃成的. 我们都知道面向对象语言的三大特征:继承.封装.多态,但JavaScript不是真正的面向对象,它只是基于面向对象,所以会有自己独特的地方.这里就说说JavaScript的继承是如何实现的. 学习过Java和c++的都知道,它们的继承通过类实现,但JavaScript没有类这个概念,那它通过什么机

JS继承的实现方式

前言 JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一.那么如何在JS中实现继承呢?让我们拭目以待. JS继承的实现方式 既然要实现继承,那么首先我们得有一个父类,代码如下: // 定义一个动物类 function Animal (name) { // 属性 this.name = name || 'Animal'; // 实例方法 this.sleep = function(){ console.log(this.name + '正在睡觉!'); } } // 原型方法 Animal

js继承的实现

js继承有5种实现方式: 1.继承第一种方式:对象冒充   function Parent(username){     this.username = username;     this.hello = function(){       alert(this.username);     }   }   function Child(username,password){     //通过以下3行实现将Parent的属性和方法追加到Child中,从而实现继承     //第一步:this.

js继承有5种实现方式

js继承有5种实现方式:1.继承第一种方式:对象冒充  function Parent(username){    this.username = username;    this.hello = function(){      alert(this.username);    }  }  function Child(username,password){    //通过以下3行实现将Parent的属性和方法追加到Child中,从而实现继承    //第一步:this.method是作为一

JS继承——原型的应用

前面我们知道JS是基于对象编程的一种脚本语言,在JS本着一切皆对象的原则,对象之间也涉及到了继承,不过这里的继承与我们以往学习过的继承有所不同,它运用的是对象的原型,来构造一个原型链来实现对超类对象的继承. 1.如何实现对象继承 function Box() { //Box 构造<span style="font-family:Arial;font-size:18px;">,超类对象</span> this.name = 'Lee'; } Desk.protot

5种JS继承方法

<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <meta name="author" content="http://www.jb51.net/" /> <title>5种JS继承方法</title> <script type="text/javascript"> //1

swift 继承相关

class Vehicle { var numberOfWheels: Int var maxPassengers: Int func description() -> String { return "\(numberOfWheels) wheels; up to \(maxPassengers) passengers" } init() { numberOfWheels = 1; maxPassengers = 3; } } class Bicycle: Vehicle {

JS 继承的方式

JS 继承的方式 1.使用call的方式 2. code如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <script type="text/javascript"> //继承的第二种实