js中的对象分为两种,一种是面向对象另一种是遍历对象。

面向对象在js里有两bai个层次的含义,第一种是会使用面向对象函数;第二种是构造面向对象函数。

js也是面向对象中的一种写法,不过相对于java,js是一种弱数据类型,并不是严格意义上的面向对象。但是jq就是使用面向对象的写法创作出来的js库。

面向对象有四个特点:

抽象:抓住核心问题

封装:即把能够实现功能的函数写成封装起来,在面向对象里叫做方法。简单来说就是把实现功能的函数写成方法。

继承:继承的意思是,在实现同一种功能的前提下,新对象可以使用就对象的属性和方法。

多态:一个变量在引用不同类型的情况下的不同状态。多态开发在开发组件和模块化开发的时候能节省很多资源。

创建对象的方法

1、new 操作符 + Object 创建对象

var person = new Object();

person.name = "lisi";

person.age = 21;

person.family = ["lida","lier","wangwu"];

person.say = function(){

alert(this.name);

}

2、字面式创建对象

var person ={

name: "lisi",

age: 21,

family: ["lida","lier","wangwu"],

say: function(){

alert(this.name);

}

};

3、工厂模式

function createPerson(name,age,family) {

var o = new Object();

o.name = name;

o.age = age;

o.family = family;

o.say = function(){

alert(this.name);

}

return o;

}

var person1 = createPerson("lisi",21,["lida","lier","wangwu"]); //instanceof无法判断它是谁的实例,只能判断他是对象,构造函数都可以判断出

var person2 = createPerson("wangwu",18,["lida","lier","lisi"]);

console.log(person1 instanceof Object); //true

4、构造函数模式

function Person(name,age,family) {

this.name = name;

this.age = age;

this.family = family;

this.say = function(){

alert(this.name);

}

}

var person1 = new Person("lisi",21,["lida","lier","wangwu"]);

var person2 = new Person("lisi",21,["lida","lier","lisi"]);

console.log(person1 instanceof Object); //true

console.log(person1 instanceof Person); //true

console.log(person2 instanceof Object); //true

console.log(person2 instanceof Person); //true

console.log(person1.constructor); //constructor 属性返回对创建此对象的数组、函数的引用

对比工厂模式有以下不同之处:

1、没有显式地创建对象

2、直接将属性和方法赋给了 this 对象

3、没有 return 语句

以此方法调用构造函数步骤:

1、创建一个新对象

2、将构造函数的作用域赋给新对象(将this指向这个新对象)

3、执行构造函数代码(为这个新对象添加属性)

4、返回新对象 ( 指针赋给变量person ??? )

可以看出,构造函数知道自己从哪里来(通过 instanceof 可以看出其既是Object的实例,又是Person的实例)

构造函数也有其缺陷,每个实例都包含不同的Function实例( 构造函数内的方法在做同一件事,但是实例化后却产生了不同的对象,方法是函数 ,函数也是对象)

因此产生了原型模式

5、原型模式

function Person() {

}

Person.prototype.name = "lisi";

Person.prototype.age = 21;

Person.prototype.family = ["lida","lier","wangwu"];

Person.prototype.say = function(){

alert(this.name);

};

console.log(Person.prototype); //Object{name: 'lisi', age: 21, family: Array[3]}

var person1 = new Person(); //创建一个实例person1

console.log(person1.name); //lisi

var person2 = new Person(); //创建实例person2

person2.name = "wangwu";

person2.family = ["lida","lier","lisi"];

console.log(person2); //Person {name: "wangwu", family: Array[3]}

// console.log(person2.prototype.name); //报错

console.log(person2.age); //21

原型模式的好处是所有对象实例共享它的属性和方法(即所谓的共有属性),此外还可以如代码第16,17行那样设置实例自己的属性(方法)(即所谓的私有属性),可以覆盖原型对象上的同名属性(方法)。

6、混合模式(构造函数模式+原型模式)

构造函数模式用于定义实例属性,原型模式用于定义方法和共享的属性

function Person(name,age,family){

this.name = name;

this.age = age;

this.family = family;

}

Person.prototype = {

constructor: Person, //每个函数都有prototype属性,指向该函数原型对象,原型对象都有constructor属性,这是一个指向prototype属性所在函数的指针

say: function(){

alert(this.name);

}

}

var person1 = new Person("lisi",21,["lida","lier","wangwu"]);

console.log(person1);

var person2 = new Person("wangwu",21,["lida","lier","lisi"]);

console.log(person2);

可以看出,混合模式共享着对相同方法的引用,又保证了每个实例有自己的私有属性。最大限度的节省了内存。

高程中还提到了动态原型模式,寄生构造函数模式,稳妥构造函数模式。

给对象添加修改数据的方法

给JS对象添加属性和方法

方式一:在定义对象时,直接添加属性和方法

function Person(name,age) {

this.name = name;

this.age = age;

this.say = function() {

alert(name + ':::' + age);

}

}

var person = new Person('张三', 24);

person.say();

方式二:通过"对象.属性名"的方式添加

function Person() {}

var person = new Person();

person.name = '张三';

person.say = function() {alert(this.name)};

person.say();

方式三:通过prototype(原型)属性添加

注:需要使用构造方法添加!

function Person() {}

var person = new Person();

Person.prototype.name = '张三';

Person.prototype.say = function() {alert(this.name)};

person.say();

本文地址:https://blog.csdn.net/hanbic/article/details/107298174

希望与广大网友互动??

点此进行留言吧!

什么是创建对象java_什么是对象,以及对象的创建和方法相关推荐

  1. java创建数组对象_java对象数组 创建对象数组,初始化对象数组

    对象数组的概念: 如果一个数组中的元素是对象类型,则称该数组为对象数组. 当需要一个类的多个对象时,应该用该类的对象数组来表示,通过改变下标值就可以访问到不同的对象. 对象数组的定义和使用: 对象数组 ...

  2. layui根据name获取对象_JavaScript对象 - 初识

    什么是对象? 什么是对象: 其实就是一种类型,即[引用]类型.而对象就是[引用类型]的实例.在ECMAScript 中引用类型是一种[数据结构],用于将[数据和功能]组织在一起. 分析数据存储的历程: ...

  3. 创建函数查找上级_一文秒懂JavaScript中对象的7种创建方式

    1.工厂模式 javascript 代码 工厂模式:能根据接受的参数来创建出一个person对象.也可以无数次的调用这个函数,每次都会返回一个包含3个属性和1个方法的对象. 工厂模式虽然解决了创建多个 ...

  4. Java07-day07【类和对象、对象内存图、成员变量与局部变量、private、this、封装、构造方法】

    java零基础入门到精通(2019版)[黑马程序员] 视频+资料:[链接:https://pan.baidu.com/s/1MdFNUADVSFf-lVw3SJRvtg   提取码:zjxs] &qu ...

  5. 对象、对象的属性、对象字面量、枚举对象中的属性、可变类型、变量和对象——JS对象

    目录 一.对象 二.对象的属性 三.对象字面量 四.枚举对象中的属性 五.可变类型 六.变量和对象 数据类型: 原始值:(不可变类型) 1.数值 Number 2.大整数 BigInt 3.字符串 S ...

  6. java对象——new对象的理解

    学了好长时间的java对于java中的对象一直没有理清楚,今天楼主对java中的对象进行了整理,希望对大家有帮助. 理解和使用java中的对象,我们首先了解一下构造方法与对象的创建.  类是面向对象语 ...

  7. 【Java】day21--装饰者设计模式、序列流对象、对象输入输出流、Properties配置文件部分知识点总结

    (一)继承增强一个类的功能 BufferedReader    对FileReader拓展了一个功能,readLine. 需求1:编写一个类对BufferedReader的功能进行增强,增强其read ...

  8. js - 关于对象,数组和字符串的方法 总结

    javascript中关于对象,数组和字符串的一些方法总结. 1,引用数据类型 object 1.Object.is() 是一种判断两个值是否相同的方法. 语法:Object.is(value1, v ...

  9. 享元模式——对象共享,避免创建多对象

    1. 享元模式介绍 享元模式是对象池的一种实现,它的英文名称叫做Flyweight,代表轻量级的意思.享元模式用来尽可能减少内存使用量,他适合用于可能存在大量重复对象的场景,来缓存可共享的对象,达到对 ...

  10. 初学JavaScript:js中的对象(对象+原型对象)

    文章目录 js对象详解 1.创建对象 字面量模式创建对象 构造函数模式创建对象 2.访问对象 访问属性 访问方法 3.遍历对象中的属性和属性值 4.往对象中新添属性 5.删除对象中的属性 6.Obje ...

最新文章

  1. 不知道这些,简历上千万不要说你会 Redis 持久化。。。
  2. 【转】QString 与中文问题
  3. Python爬虫小实践:爬取任意CSDN博客所有文章的文字内容(或可改写为保存其他的元素),间接增加博客访问量...
  4. javascript变量提前声明
  5. Java 并发编程-不懂原理多吃亏(送书福利)
  6. poj 1451(Trie)
  7. java 不允许默认构造_java – 如何使用ObjectMapper去除/序列化不可变对象而不使用默认构造函数?...
  8. 使用html+css仿搜狐网址页面布局
  9. Chisel3 - Tutorial - Parity
  10. 从 Google 的一道面试题说起·
  11. HDU2526 浪漫手机【模拟】
  12. 阿里菜鸟java后台开发电话面试
  13. 测试用例设计方法大全下——场景法、、错误推测法、正交法
  14. h5 标签video和audio标签的下载按钮
  15. MySQL 数据库删除操作中的 delete、drop、 truncate 区别在哪?
  16. 北欧计算机专业出国,留学北欧,哪个国家计算机专业比较好?
  17. 软考之数字签名 对称加密 非对称加密
  18. 历年国二c语言真题百度网盘 下载,历年国家计算机二级C语言上机国二真题整理100套...
  19. docker 搭建在线office--onlyoffice (二)
  20. jlink怎么调试linux程序_使用jlink+gdbserver+insight调试ARM程序--配置insight

热门文章

  1. vue3 友盟统计埋点
  2. 杭州奇侠互动网络科技游戏测试笔试题
  3. 关于QQ记录查看软件...
  4. 第9关:生成器与 yield
  5. xcode pods 总结
  6. iis打不开默认的ie浏览器
  7. 大学生所面临的网络安全问题有哪些?
  8. 射频电路基础(赵建勋) ----调制与解调 笔记
  9. ECharts县级市地图Json制作
  10. 【Java 8 in Action】Lambda表达式