zoukankan      html  css  js  c++  java
  • JavaScript 继承机制小记

    读《JavaScript: the good parts》, 关于对象继承这块小记一笔:

    function Base(v){
        this.baseValue = v;
        this.getBaseValue = function(){
            return this.baseValue;
        };
    }
    
    function TestObject(base, c){
        var temp = function(){
            this.content = c;
            this.fromBaseValue = function(){
                return this.baseValue;
            };
        };
    
        temp.prototype = base;
    
        return new temp();
    }
    
    var b1 = new Base(1);
    
    var t1 = new TestObject(b1, 'this is t1');
    var t2 = new TestObject(b1, 'this is t2');
    
    console.log('t1', {'baseValue':t1.baseValue, 'fromBaseValue()': t1.fromBaseValue(), 'getBaseValue()':t1.getBaseValue()})
    console.log('t2', {'baseValue':t2.baseValue, 'fromBaseValue()': t2.fromBaseValue(), 'getBaseValue()':t2.getBaseValue()})
    //t1 { baseValue: 1, 'fromBaseValue()': 1, 'getBaseValue()': 1 }
    //t2 { baseValue: 1, 'fromBaseValue()': 1, 'getBaseValue()': 1 }
    
    b1.baseValue = 2
    
    console.log('t1', {'baseValue':t1.baseValue, 'fromBaseValue()': t1.fromBaseValue(), 'getBaseValue()':t1.getBaseValue()})
    console.log('t2', {'baseValue':t2.baseValue, 'fromBaseValue()': t2.fromBaseValue(), 'getBaseValue()':t2.getBaseValue()})
    //t1 { baseValue: 2, 'fromBaseValue()': 2, 'getBaseValue()': 2 }
    //t2 { baseValue: 2, 'fromBaseValue()': 2, 'getBaseValue()': 2 }
    
    t1.baseValue = 3;
    //If we try to retrieve a property value from a object, and if the object lacks the property name,
    //then JavaScript attemps to retrieve the property value from the prototype object.
    console.log('t1', {'baseValue':t1.baseValue, 'fromBaseValue()': t1.fromBaseValue(), 'getBaseValue()':t1.getBaseValue()})
    console.log('t2', {'baseValue':t2.baseValue, 'fromBaseValue()': t2.fromBaseValue(), 'getBaseValue()':t2.getBaseValue()})
    //t1 { baseValue: 3, 'fromBaseValue()': 3, 'getBaseValue()': 3 }
    //t2 { baseValue: 2, 'fromBaseValue()': 2, 'getBaseValue()': 2 }
    
    b1.baseValue = 4
    
    console.log('t1', {'baseValue':t1.baseValue, 'fromBaseValue()': t1.fromBaseValue(), 'getBaseValue()':t1.getBaseValue()})
    console.log('t2', {'baseValue':t2.baseValue, 'fromBaseValue()': t2.fromBaseValue(), 'getBaseValue()':t2.getBaseValue()})
    //t1 { baseValue: 3, 'fromBaseValue()': 3, 'getBaseValue()': 3 }
    //t2 { baseValue: 4, 'fromBaseValue()': 4, 'getBaseValue()': 4 }
  • 相关阅读:
    android 75 新闻列表页面
    android 74 下载文本
    android 73 下载图片
    android 72 确定取消对话框,单选对话框,多选对话框
    android 71 ArrayAdapter和SimpleAdapter
    android 70 使用ListView把数据显示至屏幕
    maven如何将本地jar安装到本地仓库
    Centos6.7搭建ISCSI存储服务器
    解决maven打包编译出现File encoding has not been set问题
    MySQL 解决 emoji表情 的方法,使用utf8mb4 字符集(4字节 UTF-8 Unicode 编码)
  • 原文地址:https://www.cnblogs.com/straybird/p/3158723.html
Copyright © 2011-2022 走看看