首页
学习
活动
专区
工具
TVP
发布

Js如何创建一个自定义对象

前言 JS中分两种数据类型,一种是基本数据类型,另外就是复杂数据类型,在描述一个事物对象,当比较复杂时,一般可以用数组和对象来存储 在Js中的对象,指的是一系列互相嵌套的键值对,在做web开发时,大多数控件都是以对象或数组的形式来提供给开发人员使用...那如何创建一个对象呢,如何给对象添加属性和方法?...在Js当中有一些方法,如下所示 01 方法1-使用文本字面量形式 这种方法创建对象是比较直接,常见的一种方式,就是使用大括号的方式,可以看做是js对象的本本标识,也就是说,可以通过输出字符串的形式来了解对象有哪些键值对...,它也是JSON形式,用于js的数据存储和传递,给对象添加属性和添加方法 如下代码所示 // 用大括号创建对象的方法,这种方法最常见,使用最频繁 var obj1 = {}; // 使用大括号创建一个内容为空的对象...添加了一个outPut方法,并提供实现了一个alert弹框 alert('给obj1添加了一个outPut方法'); } // 调用对象obj1下面的outPut方法 obj1.outPut()

4.6K20
您找到你想要的搜索结果了吗?
是的
没有找到

JS面向对象

JS面向对象 理解对象 数据(数据描述符)属性 数据属性有4个描述内部属性的特性 [[Configurable]] 表示能否通过delete删除此属性,能否修改属性的特性,或能否修改把属性修改为访问器属性...默认为 undefined [[Set]] 一个给属性提供 setter 的方法(给对象属性设置值时调用的函数),如果没有 setter 则为 undefined。...默认为 undefined 创建/修改/获取属性的方法 Object.defineProperty() 功能:方法会直接在一个对象上定义一个新属性,或者修改一个对象的现有属性, 并返回这个对象。...enumerable: true, value: '张三' }) console.log(obj.name) // 张三 Object.defineProperties() 功能:方法直接在一个对象上定义一个或多个新的属性或修改现有属性...语法: Object.defineProperties(obj, props) obj: 将要被添加属性或修改属性的对象 props: 该对象一个或多个键值对定义了将要为对象添加或修改的属性的具体配置

7.3K20

js对象

课程目标: 1.掌握面向对象的基本操作. 2.掌握构造函数的优化策略. 3.创建对象的方式. 1.创建对象的三种方式: <!....方法名=function() { //输出内容 } let 对象名=new Object(); 对象名.属性; 对象名.方法名(); //第二种方式: let 对象名={}; 对象名.属性名=属性;..."); } console.log(demo===demo); 总结: 构造函数与普通函数的区别: 1.在同一个构造函数创建出来的对象是不一样的...为了使内存地址一样,不占用内存把. 1.调用了同一个普通函数. ? ? 效果: ? 第二奏: <!...1.调用对象是一样的,比如我爱你。他也爱你.是不是爱的是一个人啊。 2.调用构造函数是不一样的,为什么,因为他是类中的。类是一个整体不是个体啊. 效果: ? <!

6.8K10

js对象属性

(let p in zhangsan){ console.log(zhangsan.hasOwnProperty(p),`${p}:${zhangsan[p]}`) } 参考代码 codepen关于js...方法 内容 备注 for in 可枚举,自身以及继承属性 对象以及继承,可枚举,不含 Symbol 属性 Object.keys(obj) 返回一个数组,包括对象自身的(不含继承的)所有可枚举属性键名...对象自身可枚举,不含 Symbol 属性 Object.getOwnPropertyNames(obj) 返回一个数组,包含对象自身的所有属性(不含 Symbol 属性,但是包括不可枚举属性)的键名 对象自身...,包括不可枚举属性 Object.getOwnPropertySymbols(obj) 返回一个数组,包含对象自身的所有 Symbol 属性的键名 对象自身,symbol Reflect.ownKeys...(obj) 返回一个数组,包含对象自身的所有键名,不管键名是 Symbol 或字符串,也不管是否可枚举。

15.6K10

Js Array对象

Array对象 常用方法 在数组末尾添加一个或多个元素 - push() 在数组末尾添加一个或多个元素,返回新长度,会修改原数组 var arr = [1, 2, 3, 4, 5] var len1...rearr = arr.reverse() console.log(rearr); // [5, 4, 3, 2, 1] console.log(arr); // [5, 4, 3, 2, 1] 判断一个对象是否是数组...index) { console.log("值", val) console.log("索引", index) }) console.log(arr) //不会修改原数组 伪数组 将一个伪数组对象转换为一个真正的数组...2、该类数组对象的属性名必须为数值型或字符串型的数字 ps: 该类数组对象的属性名可以加引号,也可以不加引号 let arrayLike = { 0: 'tom', 1: '65',...(拥有一个 length 属性和若干索引属性的任意对象)或可迭代对象转换为真正的数组。

7.6K10

JS面向对象

面向对象特点封装 让使用的人不考虑内部实现,只考虑功能使用,把内部代码保护起来,提供api接口让用户调用继承 从父类继承出一些方法和属性,利于代码复用多态 不同对象作用于同一操作产生不能效果JS三大对象宿主对象所有非本地对象都属于宿主对象所有...DOM和BOM对象都属于宿主对象嵌入到网页的JS来说,宿主对象就是浏览器提供的,比如:Window和Documnet等本地对象包括:Object、Array、Date、RegExp、Boolean、Number...、String这些引用类型在运行过程中需要通过new来创建所需的实例对象内置对象是本地对象的子集在ECMAScript程序开始执行前就存在,本身就是实例化内置对象,开发者无需再实例化内置独享有Global...如果创建一个对象来改变它的原型,constructor就不能判断数据类型function fn(){}fn.prototype = new Array();var f = fn();console.log...优点:改变某一实例对象的方法或者属性,不影响其他的实例对象 缺点:每生成一个实例,构造函数内部方法和属性都会重新开辟一份空间Player(val) { this.color = val

8910
领券