• Javascript中的应用和呼叫继承


    申请和调用的区别

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <body>
        </body>
        <!--其实申请和调用这两个方法基本上是差不多的,区别在于调用的第二个参数可以是任意类型,
        而申请的第二个参数必须是数组,也可以是自变量(即传给构造函数的参数)-->
    
        <!--例如我们把上面的代码稍微改一下,如果此时我在新的构造函数猫时候的参数传入new cat('wsscat','cute')我们的猫能接收参数,
        但是如果此时继承是animal.call(this),没有给呼叫传第二个参数的时候,
        生成的对象中类型的值就会是未定义的,所以为了让这个值能够让动物接收,
        我们可以在动物中传入第二个参数animal.call(此,类型)-->
        <script type="text/javascript">
            function animal(type) {
                this.type = type
                this.behavior = function(){
                    console.log(this.type+" is running")
                }
           }
            function cat(name, type) {
                this.name = name
                //这里call的意思就是把animal的方法应用到cat这个对象身上
                //所以cat就继承了animal的方法
                //animal.call(this);//type undefined
                //animal.call(this,type);//type cute
                //animal.call(this,arguments[1]);//type cute
                //animal.call(this,arguments);//type ['wsscat','cute']
                animal.apply(this,arguments)//type: wsscat
            }
            console.log(new cat('wsscat','cute'))
    //      这里用适用就很方便,因为参数是数组,可以全部传给动物,而调用就要一个个地传过去
        </script>
    </html>

    继承的优化

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <!--如果构造函数这个绑定太多属性(比如一些共同方法),在实例化后会造成浪费,
        为此我们一般会使用原型链来优化,但是使用原型链之后我们的应用和呼叫的继承方法就会失效
        为此我们一般使用混合的写法,使用原型链和(申请或者电话)进行方法继承
        具体两句话
        让子的原型链指向父的实例(父实例化的对象)
        cat.prototype = new animal();
        让父的属性创建在子的这个上
        animal.call(this, type)
        本世纪的牛顿代码如下,那么就会让父原型链的属性和该上的属性都得到继承-->
        <script type="text/javascript">
            function animal(type) {
                this.type = type
                this.behavior = function() {
                    console.log(this.type + " is running")
                }
            }
            animal.prototype.action = function() {
                console.log("running")
            }
            function cat(name, type) {
                this.name = name
                animal.call(this, type)
            }
            cat.prototype = new animal();
            console.log(new cat('wsscat', 'cute'));
            (new cat('wsscat')).action() //running
        </script>
        <body>
        </body>
    </html>

    调用实现多重继承

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <body>
        </body>
        <script type="text/javascript">
    //        当然我们可以继承多个构造函数,这就是多重​​继承
            function animal(a, b) {
                this.type = 'animal'
                this.behavior = function(){
                    console.log(this.type+" is running")
                }
            }
            function wsscat(a, b) {
                this.age = 0
            }
            function cat(a, b) {
                this.name = 'wsscat'
                //这里call的意思就是把animal的方法应用到cat这个对象身上
                //所以cat就继承了animal的方法
                animal.call(this);
                wsscat.call(this);
            }
            console.log(new cat())
        </script>
    </html>

    调用实现继承

    <!DOCTYPE html>
    <html>
        <head>
            <meta charset="UTF-8">
            <title></title>
        </head>
        <body>
        </body>
        <script type="text/javascript">
    //        拨打电话这里的意思就是把动物的方法应用到猫这个对象身上,也就是动物的属性创建到了猫里面,
    //        所以猫就继承了动物的方法
            function animal(a, b) {
                this.type = 'animal'
                this.behavior = function(){
                    console.log(this.type+" is running")
                }
            }
            function cat(a, b) {
                this.name = 'wsscat'
                //这里call的意思就是把animal的方法应用到cat这个对象身上
                //所以cat就继承了animal的方法
                animal.call(this);
            }
            console.log(new cat())
        </script>
    </html>

     github地址:https://github.com/lianglixiong/javascript-note/tree/master

  • 相关阅读:
    宽度高度sizeWithFont:constrainedToSize:lineBreakMode的使用
    端口错误安卓模拟器不能启动:The connection to adb is down, and a severe error has occurred的解决办法
    树磁盘[HBase] LSM树 VS B+树
    请求方法Jsp&servlet面试题
    数组最小(百度面试题目)对升序数组,求数组中绝对值最小的元素
    类代理java设计模式动态代理(简单笔记)
    数据插入difference between count(*) and count(col) in the query
    跟踪查看oracle 执行计划获取的几种方式
    类型字节oracle 增强型时间类型以及postgresql时间类型
    类方法[笔记]Java基础加强(57天)2010年Java高新技术_张孝祥
  • 原文地址:https://www.cnblogs.com/LLX8/p/9212125.html
Copyright © 2020-2023  润新知