可以通过四种方式将键和值分配给对象。
点表示法是一种在 JavaScript 中访问对象属性的简单且常用的方法。您可以使用点表示法创建属性并将其分配给对象。这种方法允许您在创建对象后动态定义属性。
let objectName = {}; // "object literal" syntax objectName.someKey = someValue; // set property and value const value = objectName.someKey; // retrive value
易于阅读和理解。
示例:person.name 比 person['name'] 更容易解释。
简单的语法,可以快速编写。
非常适合访问具有有效标识符(字母、数字、下划线和 $)的属性。
当属性名称包含特殊字符、空格或动态时失败。
示例:person.first-name 会抛出错误;使用 person["first-name"] 代替。
示例:如果属性名称存储在变量中,则不能使用点表示法。
方括号表示法允许使用字符串或变量动态访问或操作对象属性。方括号比点符号更灵活,因为它们可以使用任何属性名称或变量。不过,它们写起来有点困难。
允许属性名称是变量或表达式。
示例:当 propName 为变量时,obj[propName] 是灵活的。
适用于包含特殊字符、空格或保留关键字的属性名称。
示例: obj["first-name"] 或 obj["class"].
在循环对象的属性时很有用。
与点表示法相比更难阅读,尤其是对于嵌套属性。
开发过程中可能无法捕获属性名称中的错误(例如 obj["naem"])。
需要更多的输入和对字符串键使用引号。
Object.defineProperty() 方法为对象定义一个新属性或更新现有属性,然后返回该对象。
let objectName = {}; // "object literal" syntax objectName.someKey = someValue; // set property and value const value = objectName.someKey; // retrive value
Object.defineProperties() 方法直接在对象上定义新属性或修改现有属性,并返回该对象。
const user = {}; Object.defineProperty(user, 'firstName', { value: 'John', writable: true, // `false` is default }); console.log('First name', user.firstName);
以上是在 JavaScript 对象中分配和检索值的方法的详细内容。更多信息请关注PHP中文网其他相关文章!