javascript创建对象的三种方法
- 2019-01-07 12:00:27
- 2,722 次阅读
- 2
面向对象:我们什么都不用管,直接找到一个会做事的”对象”来帮助我们完成任务,jQuery就是一个面向对象的例子,他们把一些方法和属性都给我们封装好了,我们可以不去了解其内部是如何实现,只要拿到它会使用就可 以了。下面是使用原生的js创建对象,会帮助我们更好的理解面向对象。
(1)最终代码图:
(2)代码过程:
<script type="text/javascript"> // 第一种方法:通过Json的方式创建对象 person = { 'name':'马行行', 'age': 18, 'gender': '男', 'sayHello' : function() { alert('你好,我是' + this.name + ',芳年' + this.age + ',性别:' + this.gender); } }; // person.sayHello(); person['sayHello'](); // 第二种方法:通过new关键字创建对象 mobile = new Object(); mobile.brand = 'huawei'; mobile.color = 'white'; mobile.introduce = function() { console.log('我的手机品牌是' + this.brand + ',颜色是' + this.color); } mobile.introduce(); // 第三种方法:通过构造函数创建对象(构造函数就是模板) // 第三种的第一种形式 Student = function() { this.name = '小明'; this.studentID = 128126; this.study = function() { alert('我叫' + this.name + ',学号:' + this.studentID); } }; s = new Student(); alert(s.name); s.study(); // 第三种的第二种形式 Car = function(newbrand,newColor) { this.brand = newbrand; this.color = newColor; this.run = function() { alert('路上跑着一辆' + this.color + this.brand); } }; c = new Car('兰博基尼','红色'); c.run(); // 第三种的第三种形式 Computer = function(obj) { this.brand = obj.newBrand; this.color = obj.newColor; this.netPlay = function() { alert('这是一台' + this.color + this.brand + '笔记本电脑'); } }; var target = {newBrand:'联想',newColor:'黑色'} var c = new Computer(target); c.netPlay(); // 第三种的第四种形式 // Desk.prototype是Desk的原型属性,只与自己的对象有关 // Desk.prototype是d的原型对象 // prototype是标准的,__proto__是非标准的,做调试用 // 如果对象中没有该属性或方法,就会到与之相关的prototype中去寻找 // 原型属性不会共享,只会添加;原型方法可以共享 Desk = function(obj) { this.length = obj.newLength; this.width = obj.newWidth; } Desk.prototype.height = '1.2米'; Desk.prototype.put = function() { alert('桌子用来摆放东西'); } var d = new Desk({newLength:'1.5米',newWidth:'1米'}); // alert(d.length); // alert(d.height); d.put(); // 第三种的第五种形式 Cup = function(obj) { this.shape = obj.newShape; this.color = obj.newColor; } Cup.prototype = { sh:function() { alert(this.shape); }, co:function() { alert(this.color); } } var cu = new Cup({newShape:'圆形',newColor:'蓝色'}); alert(cu.shape); cu.sh(); cu.co(); // 第三种的第六种形式 Blog = function(obj) { this._init(obj) } Blog.prototype = { _init:function(obj) { this.domain = obj.domain; this.host = obj.host; }, display:function() { alert(this.domain + this.host); } } var b = new Blog({domain:'maxing128.com',host:'阿里云'}); b.display(); alert(b.domain); </script>
文章评论 (0)