首页 > 代码库 > js---14公有私有成员方法
js---14公有私有成员方法
var ns1 = {}; //命名空间 ns1.ns11 = {};//子命名空间 ns1.module1 = {name:"a",m:function(){}}; console.log(ns1.module1.name); ns1.ns11.module = {name:"a",m:function(){}}; //成员封装 //1.静态成员 function Person(name,age){ //Person既可以看成是函数,也可以看成是类,也可以看成是对象 this.name = name; } Person.u = true;//添加静态成员 console.log(Person.u);//true var p1 = new Person(); console.log(p1.u);//undefined,变量不能访问静态成员, console.log(Person.__proto__);//Person本身看成是一个对象,他是Function构造出来的, //2.公有方法 function Person(name){ var age = 100;//私有成员 function pm(){//私有方法 console.log("private"); } this.name = name;//公有成员 this.t = function(){//公有方法 console.log("pnblick"); } } var p1 = new Person(111); console.log(p1.age);//undefined console.log(p1.name);//111 p1.pm();//不能访问 p1.t();//pnblick //公有方法调用私有方法 function Person (pname) { var age = 100;//私有属性 function pm(){//私有函数,私有函数访问公有属性, console.log(this.name); } this.name = pname;//公有成员 this.test=function(){//公有方法 console.log("public method"); //pm(); pm()前面不写表示window.pm(),所以pm()函数里面的this是window, pm.call(this); }; } var p2 = new Person(); p2.test(); function Person(pname){ function pm(){ console.log(self.name);//闭包:子类访问父类的成员self,不是this,this就是window } var self = {//对象 name:pname, test:function(){ pm();//函数执行没有return,不存在对象,就是函数调用, } }; return self; } var p2 = new Person(“ss”); p2.test();//ss
js---14公有私有成员方法
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。