zoukankan      html  css  js  c++  java
  • JavaScript中实现私有属性的写类方式(2)

    上一篇写了个工具函数$class,这篇再完善以下。实现以下功能

    1,继承

    2,子类继承父类时,不继承父类的私有属性

    /**
     * @param {String} className
     * @param {String/Function} superCls
     * @param {Function} classImp
     */
    function $class(className, superCls, classImp){
    	if(superCls === '') superCls = Object;
    	function clazz(){
    		if(typeof this.init == "function"){
    			this.init.apply(this, arguments);
    		}
    	}
    	var p = clazz.prototype = new superCls();
    	var _super = superCls.prototype;
    	window[className] = clazz;
    	classImp.apply(p, [_super]);
    }
    
    
    

    先写个父类

    /**
     * 父类 Person
     */
    $class('Person','',function(){
    	// 私有属性age
    	var age;
    	this.init = function(n, a){
    		// 公有属性name
    		this.name = n;
    		// 私有属性初始化
    		age = a;
    	};
    	this.getName = function(){
    		return this.name;
    	};
    	this.setName = function(name){
    		this.name = name;
    	}
    	this.getAge = function(){
    		return age;
    	};
    	this.setAge = function(a){
    		age = a;
    	};
    });
    

    写子类,继承于Person

    $class("Man",Person, function(supr){
    	var school;
    	this.init = function(n, a, s){
    		supr.init.apply(this, [n,a]);
    		school = s;
    	}
    	this.getSchool = function(){
    		return school;
    	};
    	this.setSchool = function(s){
    		school = s;
    	};
    });
    

    new一个子类实例

    var m = new Man('tom', 25, 'pku');
    console.log(m.name); // tom 继承父类的共有属性name可以直接使用点操作符获取
    console.log(m.age);  // undefined 父类的私有属性age不能直接使用点操作符获取
    console.log(m.getAge()); // 25 可通过父类的共有方法getAge获取私有属性age
    console.log(m.school); // undefined Man自己的私有属性仍然不能通过点操作符获取
    console.log(m.getSchool()); // pku 通过getSchool()方法获取私有属性school
    
  • 相关阅读:
    内存映射mmap的几个api及其使用
    hiredis的安装
    Linux 下解压大全
    redis内存数据库C客户端hiredis API 中文说明
    C/C++使用MySQL
    搜索引擎的缓存(cache)机制
    快速排序(QuickSort)
    冒泡排序
    spring核心之AOP学习总结一
    Spring学习总结六——SpringMVC一
  • 原文地址:https://www.cnblogs.com/snandy/p/2020066.html
Copyright © 2011-2022 走看看