专业游戏门户,分享手游网游单机游戏百科知识攻略!

嗨游网
嗨游网

什么是字面量?JS中怎么利用字面量创建对象?

来源:小嗨整编  作者:小嗨  发布时间:2024-03-20 08:29
摘要:javascript中怎么利用字面量创建对象?下面本篇文章带大家了解一下字面量,介绍一下javascript中如何利用对象字面量来创建对象,希望对大家有所帮助!什么是字面量字面量(literal)是表达一个固定值的表示法,又叫常量,用来为变...

javascript中怎么利用字面量创建对象?下面本篇文章带大家了解一下字面量,介绍一下javascript中如何利用对象字面量来创建对象,希望对大家有所帮助!

什么是字面量?JS中怎么利用字面量创建对象?

什么是字面量

字面量(literal)是表达一个固定值的表示法,又叫常量,用来为变量赋值时的常数量 

通俗的理解,字面就是所见即所得,js 程序执行到代码中的字面量,会立即知道它是什么类型的数据,值是多少

可以用于表示固定值,比如:数字、字符串、undefined、布尔类型、对象的字面值等

对象字面量创建对象

对象字面量的方式是最常用的创建对象的方式之一,它用内含属性的花括号{...}快速创建对象。

var 对象名={     .....};
登录后复制

对象字面值是封闭在花括号对({})中的一个对象的零个或多个“属性名:值”列表。

示例:

var person={     name:"Jack",     age:10,    5:true  };
登录后复制

在这个例子中,左边的花括号({)表示对象字面量的开始,因为它出现在了表达式上下文(expression context)中。

JavaScript 中的表达式上下文(expression context)指的是能够返回一个值(表达式)。

赋值操作符(=)表示后面是一个值,所以左花括号在这里表示一个表达式的开始。

同样的花括号,如果出现在一个语句上下文(statement context)中,例如跟在 if 语句条件的后面,则表示一个语句块的开始。

例子中定义了 name属性,之后是一个冒号,再后面是这个属性的值(name:"Jack")。在对象字面量中,使用逗号来分隔不同的属性,因此”Jack”后面是一个逗号。但是,在 age属性的值 10 的后面不能添加逗号,因为 age 是这个对象的最后一个属性在最后一个属性后面添加逗号,会在 IE7 及更早版本和Opera 中导致错误。

不要忘记结束大括号右边的(;

对象字面量的值的类型

对象字面量的值可以是任何数据类型包括数组字面量,函数,嵌套的对象字面量

var Swapper = {            // 数组字面量(用逗号分隔,所有都要加引号)    images: ["smile.gif", "grim.gif", "frown.gif", "bomb.gif"],    pos: {             //嵌套对象字面量        x: 40,        y: 300    },    onSwap: function() {             //函数    }};
登录后复制如果有任何的语法规则被打破,如缺少逗号或冒号或大括号,将会触发JavaScript错误。浏览器的错误信息在指出对象字面量语法错误的位置一般有帮助,但他们不一定会在指出错误的性质完全准确。

在使用对象字面量时,属性名也可以用字符串

var person={    "name":"Jack",    "age":29,    5:true};
登录后复制上述例子会创建一个对象,包含三个属性,但这里的数值属性名会自动转换为字符串。

在通过对象字面量定义对象时,实际上不会调用Object构造函数(Firefox 2及更早版本会调用Object构造函数;但Firefox3之后就不会了) 这是因为字面量法创建对象强调该对象仅是一个可变的hash映射,而不是从对象中提取的属性或方法。

属性名和变量名相同时可简写

var obj = { name: name, age: age };// ES2015中,属性名和变量名相同时可简写为:var obj = { name, age };
登录后复制

扩展属性

// 扩展属性,ES2018新特性,可用于克隆或合并对象,浅拷贝,不包括原型var obj2 = { ...obj3 };
登录后复制

以字面量方式创建的对象属性默认是可写,可枚举和可配置的

对象的调用

对象里面的属性调用 : 对象.属性名 ,这个小点 . 就理解为“ 的 ”

对象里面属性的另一种调用方式 : 对象['属性名'],注意方括号里面的属性必须加引号,我们后面会用  对象里面的方法调用:对象.方法名() ,注意这个方法名字后面一定加括号

var obj1 = {    dogName: '可可',    type: '阿拉斯加犬',    age: 5 + '岁',    color: 'red',    skill: function () {        console.log('技能' + ':' + 'bark' + ',' + 'showFilm');    }}console.log(obj1.dogName);obj1.skill();
登录后复制

说明:

对象的原型默认为Object.prototype。通过定义属性__proto__(只能使用冒号标记的属性定义)的值来变更原型。只有给出的值是对象或null,对象的原型才会被设置为给出的值,否则原型不会改变。

var obj1 = {};Object.getPrototypeOf(obj1) === Object.prototype;// truevar obj2 = { __proto__: null };Object.getPrototypeOf(obj2) === null;// truevar __proto__= {};var obj3 = { "__proto__": __proto__ };Object.getPrototypeOf(obj3) === __proto__;// true// 不使用冒号标记的属性定义,不会变更对象的原型,只是名字为__proto__的普通属性var obj4 = { __proto__ };Object.getPrototypeOf(obj4) === __proto__;// falseobj4.hasOwnProperty("__proto__");// trueObject.getPrototypeOf(obj4) === Object.prototype;// truevar obj5 = { __proto__: "not an object or null" };obj5.hasOwnProperty("__proto__");// falseObject.getPrototypeOf(obj5) === Object.prototype;// true
登录后复制

【相关推荐:javascript学习教程

以上就是什么是字面量?JS中怎么利用字面量创建对象?的详细内容,更多请关注易企推科技其它相关文章!


本文地址:网络百科频道 https://www.eeeoo.cn/wangluo/1151407.html,嗨游网一个专业手游免费下载攻略知识分享平台,本站部分内容来自网络分享,不对内容负责,如有涉及到您的权益,请联系我们删除,谢谢!


网络百科
小编:小嗨整编
相关文章相关阅读
  • 荔枝app录音怎么导出音频(荔枝app的音频怎么转成mp3格式)?

    荔枝app录音怎么导出音频(荔枝app的音频怎么转成mp3格式)?

    荔枝app录音怎么导出音频(荔枝app的音频怎么转成mp3格式)?荔枝app作为一款流行的音频录制与分享平台,让许多用户可以在其中录制属于自己的声音。但有时候,我们可能需要将荔枝app中的录音导出为MP3格式,以便在其他设备上播放。本文将为...

  • 华为应用商店app官网(华为应用商店app怎么下载)?

    华为应用商店app官网(华为应用商店app怎么下载)?

    华为应用商店app官网(华为应用商店app怎么下载)?华为应用商店App作为华为手机用户的首选应用下载平台,提供了丰富的应用程序、游戏资源,同时也保证了应用的安全性和稳定性。那么,如何从官网下载华为应用商店App呢?本文将为您详细介绍。一、...

  • 淘宝app怎么打开(淘宝app在哪里找)?

    淘宝app怎么打开(淘宝app在哪里找)?

    淘宝app怎么打开(淘宝app在哪里找)?在现代生活中,淘宝App已经成为我们购物的重要工具之一。那么,淘宝App到底怎么打开?又该如何找到并下载它呢?本文将为您详细解答。一、淘宝App的下载方法1.通过手机应用商店下载对于安卓用户:打开手...

  • 阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?

    阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?

    阴阳师辉夜姬带什么御魂(阴阳师辉夜姬值得养吗)?辉夜姬作为阴阳师中的一位强力辅助式神,凭借其独特的技能和强大的辅助能力,成为了许多玩家心仪的选择。那么辉夜姬究竟带什么御魂才能发挥最大潜力呢?本文将为您详细介绍辉夜姬的御魂搭配,并分析其值得养...

  • 阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?

    阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?

    阴阳师青行灯什么时候出的(阴阳师青行灯值得培养吗)?随着阴阳师这款手游的火热,各种式神层出不穷,其中SSR级别的式神更是备受玩家关注。青行灯作为SSR中的常青树,自出道以来便以其独特的技能和强大的实力,吸引了无数玩家的目光。阴阳师青行灯什么...

  • 阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?

    阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?

    阴阳师彼岸花什么时候出的(阴阳师彼岸花值得练吗)?彼岸花作为阴阳师中的SSR式神,首次出现在游戏中是在2016年。随后,官方推出了SP版本的彼岸花,名为“夜溟彼岸花”,并于2021年1月6日正式上线。阴阳师彼岸花值得练吗彼岸花的技能设计非常...

  • 魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?

    魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?

    魔兽世界泰兰德是什么职业(魔兽世界泰兰德幻化怎么获得)?在魔兽世界中,泰兰德是魔兽世界中暗夜精灵种族的代表性角色,她以牧师职业为主。牧师在游戏中拥有强大的治疗和辅助能力,是团队中不可或缺的重要角色。泰兰德作为一名牧师,擅长使用圣光和暗影之力...

  • 魔兽世界恶魔术士天赋加点(魔兽世界恶魔术士属性怎么堆)?

    魔兽世界恶魔术士天赋加点(魔兽世界恶魔术士属性怎么堆)?

    魔兽世界恶魔术士天赋加点(魔兽世界恶魔术士属性怎么堆)?在魔兽世界中,恶魔术士是一个以高爆发和持续伤害著称的职业。合理的天赋加点对于恶魔术士的输出至关重要。本文将为您详细介绍恶魔术士的天赋加点方法,以及如何高效堆叠属性。魔兽世界恶魔术士天赋...

  • 周排行
  • 月排行
  • 年排行

精彩推荐