Javascript 创建对象的6种方法

2024-05-13 06:58

本文主要是介绍Javascript 创建对象的6种方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Javascript开发过程中经常会遇见创建对象的时候;

下面我总结了6种常用创建对象的方法:

  • 构造函数法
  • 原型法
  • 构造函数+原型法
  • 动态原型法
  • JSON法
  • create法

1.构造函数法

其主要就是利用构造函数function来创建对象.

具体例子:

function Person(name, age, sex, phone)
{//prototythis.name  = name;this.age   = age;this.sex   = sex;this.phone = phone;//methodthis.show  = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);};
};var person1 = new Person("Li",18,"man","123456");
var person2 = new Person("Wang",18,"women","123456");person1.show();
person2.show();

注意:里面的分隔符为分号,所有的元素,包括属性和函数前面都有this;

2.原型法

其主要就是利用prototype来创建对象

具体例子:

function Person1() {};Person1.prototype.name  = "Li";
Person1.prototype.age   = 18;
Person1.prototype.sex   = "man";
Person1.prototype.phone = "123456";Person1.prototype.show = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);
};function Person2(){};Person2.prototype.name  = "Wang";
Person2.prototype.age   = 18;
Person2.prototype.sex   = "women";
Person2.prototype.phone = "123456";Person2.prototype.show = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);
};var person1 = new Person1();
var person2 = new Person2();person1.show();
person2.show();

注意:很明显,这种方法每次使用一个对象时都要创建,因为它没有构造函数进行初始化;
它的关键在于属性,还有函数都是用了prototype;

3.构造函数+原型法

这就是上面两种方法的合并,用构造函数进行数值初始化,再利用prototype来定义函数

function Person(name, age, sex, phone)
{//propotythis.name  = name;this.age   = age;this.sex   = sex;this.phone = phone;};//method
Person.prototype.show  = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);
};var person1 = new Person("Li",18,"man","123456");
var person2 = new Person("Wang",18,"women","123456");person1.show();
person2.show();

注意:function和prototype的结合;

4.动态原型法

这是原型法的进一步使用,其主要就是判断该数值或者该函数有没有被定义,如果有则不用重新定义

具体例子:

function Person(name, age, sex, phone)
{//propotythis.name  = name;this.age   = age;this.sex   = sex;this.phone = phone;//methodif (Person.prototype.show === undefined){Person.prototype.show = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);};}};var person1 = new Person("Li",18,"man","123456");
var person2 = new Person("Wang",18,"women","123456");person1.show();
person2.show();

注意:这里会判断是否定义;

5.JSON法

这种顾名思义,其创建方式就和JSON类似

具体例子:

var Person = {show : function() {console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);},name  : null,age   : null,sex   : null,phone : null,
};var person1 = Person;
var person2 = Person;person1.name  = "Li";
person1.age   = 18;
person1.sex   = "man";
person1.phone = "123456";
person1.show();person2.name  = "Wang";
person2.age   = 18;
person2.sex   = "women";
person2.phone = "123456";
person2.show();

注意,里面的分隔符要用逗号;

6.create法

这利用了对象的create方法进行创建

具体例子:


function createObject(objname,name, age, sex, phone){var person = new Object();person.objname = objname;person.name  = name;person.age   = age;person.sex   = sex;person.phone = phone;person.show  = function(){console.log("name:" + this.name);console.log("age:" + this.age);console.log("sex:" + this.sex);console.log("phone:" + this.phone);};return person;
}var person1 = createObject("person1","Li",18,"man","123456");
person1.show();var person2 = createObject("person2","Wang",18,"women","123456");
person2.show();

注意:用名字去创建一个对象,再进行初始化;


在工作中比较常用其实是:

1.构造函数+原型法

2.JSON法

3.create法

这篇关于Javascript 创建对象的6种方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/984990

相关文章

Java Predicate接口定义详解

《JavaPredicate接口定义详解》Predicate是Java中的一个函数式接口,它代表一个判断逻辑,接收一个输入参数,返回一个布尔值,:本文主要介绍JavaPredicate接口的定义... 目录Java Predicate接口Java lamda表达式 Predicate<T>、BiFuncti

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Spring Security方法级安全控制@PreAuthorize注解的灵活运用小结

《SpringSecurity方法级安全控制@PreAuthorize注解的灵活运用小结》本文将带着大家讲解@PreAuthorize注解的核心原理、SpEL表达式机制,并通过的示例代码演示如... 目录1. 前言2. @PreAuthorize 注解简介3. @PreAuthorize 核心原理解析拦截与

一文详解JavaScript中的fetch方法

《一文详解JavaScript中的fetch方法》fetch函数是一个用于在JavaScript中执行HTTP请求的现代API,它提供了一种更简洁、更强大的方式来处理网络请求,:本文主要介绍Jav... 目录前言什么是 fetch 方法基本语法简单的 GET 请求示例代码解释发送 POST 请求示例代码解释

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

SpringBoot首笔交易慢问题排查与优化方案

《SpringBoot首笔交易慢问题排查与优化方案》在我们的微服务项目中,遇到这样的问题:应用启动后,第一笔交易响应耗时高达4、5秒,而后续请求均能在毫秒级完成,这不仅触发监控告警,也极大影响了用户体... 目录问题背景排查步骤1. 日志分析2. 性能工具定位优化方案:提前预热各种资源1. Flowable