一.如何创建对象
1.对象字面量
var obj1={
name:"吻别",
singer:"张学友",
type:"流行"
}
2.构造函数
var obj=new Object();
obj.name="刘德华";
obj.age=45;
obj.hobby=function () {
console.log("唱歌");
};
3.封装简单的工厂函数 (不推荐使用)
function createSong(Name,Age){
var o=new Object();
o.name=Name;
o.age=Age;
o.hobby=function () {
console.log("让我唱首歌");
};
return o
}
var obj1=createSong("刘德华",45);
var obj2=createSong("张学友",36);
console.log(obj1.hobby()); 4.自定义构造函数
//构造函数是用来初始化对象 (给对象新增成员)
//并且和new关键字同时出现
//new是用来创建对象的
//构造函数名首字母要大写 以示区分
function Person() {
//默认隐含的操作,把刚用new新创建出的对象赋值给this
this.name="尼古拉斯";
this.age="36";
this.sayHello=function () {
console.log("hello world");
}
}
var P=new Person();//new object() 5.原型解决构造函数中的问题
//构造函数 原型解决问题
function Person(name,age,gender) {
this.name=name;
this.age=age;
this.gender=gender;
// this.sayHello=function () {
// console.log("我叫"+this.name);
// }//此处会导致代码的多次重复浪费,所以解决方法用原型
}
Person.prototype.sayHello=function () {
console.log("我叫"+this.name);
}
var p1=new Person("刘德华",18,"male"); //实例化
var p2=new Person("张学友",16,"male");//实例化
p1.sayHello();
p2.sayHello(); 6.实例化
实例化:通过构造函数创建对象的过程 7.原型对象的使用方法
//1.利用对象的动态特性给原型对象添加成员
Person.prototype.sayHello=function () {
console.log("我叫"+this.name)
};
p=new Person("刘德华",18,"male");
p.sayHello(); //2.直接替换原型对象
Person.prototype={
msg:"you are a good boy",
func:function () {
console.log(this.msg);
}
};
p1=new Person("张学友",20,"male");
//此处p1不能调用sayHello()方法,因为他是原型对象从新创建之后,创建出来的
console.log(p1.msg); 8.使用原型注意事项
1.使用对象访问属性的时候,如果在本身找不到就会去原型找
2.但是使用.语法赋值的时候并不会去原型中找
3.使用.语法赋值的时候,如果对象中不存在该属性时,就会给该对象新增该属性,而不会新增原型中的属性
4.如何在原型中的属性是引用类型属性,那么所有对象共用该属性,并且一个对象修改了该引用类型属性中
的成员,其他对象也都会受影响
5.一般情况下不会将属性放入到原型对象中去,一般情况下原型对象中只会放共享的方法 //构造函数 通过constructor可以找到构造函数
function Person(name,age,gender,car) {
this.name=name;
this.age=age;
this.gender=gender;
this.car=car;
}
var x={
brand:"byd"
};
var p1=new Person("张学友",12,"male",x);
console.log(Person.prototype.constructor);
var p2=new p1.constructor("刘德华",45,"male",x); //通过constructor可以找到构造函数
console.log(p2.name)

JS-构造函数2的更多相关文章

  1. JS构造函数的用法和JS原型

    $(function(){ var rec = new Rectangle(5, 10); //alert(rec.width + "*" + rec.height + " ...

  2. 谈谈JS构造函数

    //构造函数 //使自己的对象多次复制,同时实例根据设置的访问等级可以访问其内部的属性和方法 //当对象被实例化后,构造函数会立即执行它所包含的任何代码 function myObject(msg) ...

  3. Class和普通js构造函数的区别

    Class 在语法上更加贴合面向对象的写法 Class 实现继承更加易读.易理解 更易于写 java 等后端语言的使用 本质还是语法糖,使用 prototype Class语法 typeof Math ...

  4. js 构造函数 & 静态方法 & 原型 & 实例方法

    js 构造函数 & 静态方法 & 原型 & 实例方法 ES5 "use strict"; /** * * @author xgqfrms * @licens ...

  5. 深入研究js构造函数和原型

    很快就要从新浪离职了,最近心情比较轻松,抽点空整理一下构造函数和原型的机理. 我们都知道,在经典设计模式中我们最常用的就是工厂模式.构造函数模式.原型模式这几种,听起来‘模式’好像很高大上的样子,实际 ...

  6. js构造函数,索引数组和属性的属性

    本文主要介绍和小结js的构造函数,关联数组的实现方式和使用,及不可变对象和它的实现方式及他们使用过程中要注意的点 <script> function p(){ var len=argume ...

  7. JS构造函数原理与原型

    1.创建对象有以下几种方式: ①.var obj = {}; ②.var obj = new Object(); ③.自定义构造函数,然后使用构造函数创建对象 [构造函数和普通函数的区别:函数名遵循大 ...

  8. js 构造函数(construction)与原型(prototype)

    1.面向对象:js原型 java有class和instance,js仅仅有构造函数(function Cat(name,age){this.name=name;this.age=age}),为了实现数 ...

  9. JS构造函数、对象工厂、原型模式

    1.对象创建的3中方法 1.1.对象字面量 var obj = { name: "mingzi", work: function () { console.log("wo ...

  10. 完整原型链详细图解之JS构造函数、原型 原型链、实例化对象

    一.首先说一下什么是构造函数: 构造函数:用来在创建对象时初始化对象.特点:构造函数名一般为大写字母开头:与new运算符一起使用来实例化对象. 举例: function Person(){} //Pe ...

随机推荐

  1. python实现常量const

    新建const.py: #-*-coding:UTF-8-*- #Filename: const.py # 定义一个常量类实现常量的功能 # # 该类定义了一个方法__setattr()__,和一个异 ...

  2. 【译】理解node.js事件轮询

    Node.js的第一个基本论点是I/O开销很大. 当前编程技术中等待I/O完成会浪费大量的时间.有几种方法可以处理这种性能上的影响: 同步:每次处理一个请求,依次处理.优点:简单:缺点:任何一个请求都 ...

  3. bzoj4591 / P4345 [SHOI2015]超能粒子炮·改

    P4345 [SHOI2015]超能粒子炮·改 题意:求$\sum_{i=1}^{k}C(n,i)\%(P=2333)$ 肯定要先拆开,不然怎么做呢(大雾) 把$C(n,i)$用$lucas$分解一下 ...

  4. 了解微信小程序

    了解微信小程序 版权声明:未经博主授权,内容严禁转载分享! 微信小程序官方网址:https://mp.weixin.qq.com/cgi-bin/wx 某大神知乎专栏地址:七月在夏天 https:// ...

  5. Program Size

    在Keil中编译工程成功后,在下面的Bulid Ouput窗口中会输出下面这样一段信息: Program Size: Code=6320  RO-data=4864  RW-data=44  ZI-d ...

  6. assert函数用法总结【转】

    本文转载自:http://blog.csdn.net/u014082714/article/details/45190505 assert宏的原型定义在<assert.h>中,其作用是如果 ...

  7. Linux上Java的安装与配置

    由于使用 yum 或者 apt-get 命令 安装 openjdk 可能存在类库不全,从而导致用户在安装后运行相关工具时可能报错的问题,所以此处我们推荐采用手动解压安装的方式来安装 JDK.具体步骤如 ...

  8. BZOJ2982: combination Lucas

    Description LMZ有n个不同的基友,他每天晚上要选m个进行[河蟹],而且要求每天晚上的选择都不一样.那么LMZ能够持续多少个这样的夜晚呢?当然,LMZ的一年有10007天,所以他想知道答案 ...

  9. [不屈的复习] - 编辑工具IDE选取与Hello World

    大家真正在工作中开发 java 应用都会使用eclipse,myeclipse, IntelliJ IDEA等等 现在还有vscode也支持了java扩展 在控制台下运行第一个Java程序,可以看到输 ...

  10. Darknet卷基层浅层特征可视化教程

    目录 Darknet浅层可视化教程 说明 处理步骤 使用python可视化txt文件 Darknet浅层可视化教程 说明 针对YOLO官方提供的c语言版的darknet进行了修改,添加了一些函数,进行 ...