JavaScript获取自身对象

使用HTML创建交互式性别选择器

 

<html>

<head>

<script>
function getSelf(e){
	alert ("id:"   + e.id);
	alert ("name:" + e.name)
}
</script>

</head>

<body>
	<input id="sex_0" type="radio" name="sex" onclick="getSelf(this)"><label for="sex_0">男</label>
	<input id="sex_1" type="radio" name="sex" onclick="getSelf(this)"><label for="sex_1">女</label>
</body>

</html>
JavaScript 提供了多种方法来获取对象中的键值对,这些方法在不同的场景下各有优势。以下是几种常见的方式: ### 使用 `Object.entries()` `Object.entries()` 方法返回一个给定对象自身可枚举属性的键值对数组。这个方法非常适合用来遍历对象中的键值对,尤其是在需要同时访问键和值的情况下。 ```javascript const obj = { name: 'Alice', age: 25 }; for (const [key, value] of Object.entries(obj)) { console.log(`Key: ${key}, Value: ${value}`); } ``` ### 使用 `Object.keys()` 和 `map()` 如果只需要对象的键,可以使用 `Object.keys()` 方法获取所有键的数组,然后通过 `map()` 方法映射到对应的值。 ```javascript const obj = { name: 'Alice', age: 25 }; const keyValuePairs = Object.keys(obj).map(key => [key, obj[key]]); console.log(keyValuePairs); // 输出: [ ['name', 'Alice'], ['age', 25] ] ``` ### 使用 `for...in` 循环 `for...in` 循环可以用来遍历对象的所有可枚举属性,包括继承的属性。因此,在使用此方法时需要注意,通常需要配合 `hasOwnProperty()` 方法来确保只处理对象自身的属性。 ```javascript const obj = { name: 'Alice', age: 25 }; for (const key in obj) { if (obj.hasOwnProperty(key)) { console.log(`Key: ${key}, Value: ${obj[key]}`); } } ``` ### 使用 `Reflect.ownKeys()` `Reflect.ownKeys()` 方法返回一个数组,包含对象自身的所有属性键,无论是可枚举还是不可枚举的,包括符号属性键。 ```javascript const obj = { name: 'Alice', age: 25 }; const ownKeys = Reflect.ownKeys(obj); ownKeys.forEach(key => { console.log(`Key: ${key}, Value: ${obj[key]}`); }); ``` ### 使用 `Object.getOwnPropertyNames()` `Object.getOwnPropertyNames()` 方法返回一个数组,包含对象自身所有的可枚举和不可枚举的属性键。 ```javascript const obj = { name: 'Alice', age: 25 }; const propertyNames = Object.getOwnPropertyNames(obj); propertyNames.forEach(key => { console.log(`Key: ${key}, Value: ${obj[key]}`); }); ``` ### 使用 `Object.values()` 和 `Object.keys()` 如果只需要获取值或者键,可以分别使用 `Object.values()` 和 `Object.keys()` 方法。这两个方法分别返回对象的值数组和键数组。 ```javascript const obj = { name: 'Alice', age: 25 }; const keys = Object.keys(obj); const values = Object.values(obj); console.log(keys); // 输出: ['name', 'age'] console.log(values); // 输出: ['Alice', 25] ``` 以上方法中,`Object.entries()` 是最直接的方式来获取键值对,而其他方法则提供了更多的灵活性,可以根据具体需求选择合适的方法[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值