JS遍历对象的方法及特点

这篇具有很好参考价值的文章主要介绍了JS遍历对象的方法及特点。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、定义一个对象

    let obj = {
        name: 'Tom',
        age: '20',
        sex: '男',
    };
    obj.weight = '70kg';

    // obj的原型上定义属性
    Object.prototype.height = '180cm';
    Object.prototype.major = function() {
        console.log('专业:计算机应用技术');
    };

    console.log('obj', obj);

控制台输出的obj中,原型Object上添加了height和major

JS遍历对象的方法及特点,JavaScript,javascript

2、使用 for…in 循环遍历对象的属性

for…in遍历属性时,包含该实例对象的自有属性和该实例对象上的原型属性,不包含不可枚举的属性

    for (let key in obj) {
        console.log(key, ':', obj[key]);
    }

控制台输出结果:

根据输出结果可知for……in 遍历对象会遍历实例对象原型上添加的属性。

JS遍历对象的方法及特点,JavaScript,javascript

3、Object.prototype.hasOwnProperty()

hasOwnProperty()用来检测某个属性是否是实例对象的自有属性,返回一个布尔值,若返回true,则是实例对象的自有属性,若返回false,则不是。

hasOwnProperty() 是定义在 Object.prototype 对象上的的原型方法,Object 的所有实例对象都会继承该方法。

    console.log('name: ', obj.hasOwnProperty('name'));         // true
    console.log('weight: ', obj.hasOwnProperty('weight'));     // true
    console.log('height: ', obj.hasOwnProperty('height'));     // false
    console.log('major: ', obj.hasOwnProperty('major'));       // false

控制台输出结果:

JS遍历对象的方法及特点,JavaScript,javascript

所以可以使用for……in结合hasOwnProperty()遍历实例对象的自有属性

    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
            console.log(key, ':', obj[key]);
        }
    }

控制台输出结果:

JS遍历对象的方法及特点,JavaScript,javascript

4、使用Object.keys()方法获取实例对象的所有属性,然后使用forEach()方法遍历属性

Object.keys()静态方法返回一个由给定对象自身的可枚举的字符串键属性名组成的数组。

    console.log(Object.keys(obj));
    
    Object.keys(obj).forEach((key) => {
        console.log(key, ':', obj[key]);
    })

控制台输出结果:

根据输出结果可知Object.keys()方法不会获取到实例对象的原型上添加的属性。

JS遍历对象的方法及特点,JavaScript,javascript

5、Object.getOwnPropertyNames()结合forEach()

Object.getOwnPropertyNames()静态方法返回一个数组,其包含给定对象中所有自有属性(包括不可枚举属性,但不包括使用 symbol 值作为名称的属性)。

    console.log(Object.getOwnPropertyNames(obj));

    Object.getOwnPropertyNames(obj).forEach((key) => {
        console.log(key, ':', obj[key]);
    })

控制台输出结果:

JS遍历对象的方法及特点,JavaScript,javascript

参考:

1、Object.keys()

2、Object.prototype.hasOwnProperty()

3、Object.getOwnPropertyNames()文章来源地址https://www.toymoban.com/news/detail-805172.html

到了这里,关于JS遍历对象的方法及特点的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • JavaScript 中遍历字典(对象)的键(key)和值(value)

    要在 JavaScript 中遍历字典(对象)的键(key)和值(value),可以使用 Object.entries() ​ 方法。这个方法会返回一个由键值对(key-value pairs)组成的数组,然后可以使用 for...of ​ 循环或数组的 forEach() ​ 方法遍历键值对。 以下是使用 for...of ​ 循环和 forEach() ​ 方法遍历字典

    2024年02月15日
    浏览(38)
  • JavaScript 手写代码 第七期(重写数组方法三) 用于遍历的方法

    我们在日常开发过程中,往往都是取出来直接用,从来不思考代码的底层实现逻辑,但当我开始研究一些底层的东西的时候,才开始理解了JavaScript每个方法和函数的底层实现思路,我认为这可以很好的提高我们的代码水平和逻辑思维。 2.1.1 基本使用 forEach() 方法用于调用数组

    2024年02月12日
    浏览(52)
  • 【JavaScript精通之道】掌握数据遍历:解锁现代化遍历方法,提升开发效率!

    ​ 🎬 岸边的 风 :个人主页  🔥  个人专栏  :《 VUE 》 《 javaScript 》 ⛺️  生活的理想,就是为了理想的生活 ! ​ 目录  📚 前言  📘 1. reduce方法 📘 2. forEach方法 📘 3. map方法  📘 4. for循环 📘 5. filter方法 📘 6. for...of循环 📘 7. Object.keys方法 📘 8. Object.values方法 📘

    2024年02月10日
    浏览(46)
  • js遍历对象的方法

    遍历 对象的方法         一、for...in                二、Object.keys()         三、Object.getOwnPropertyNames() 一、for...in                  for in循环是最基础的遍历对象的方式,它还会得到对象原型链上的属性 二、Object.keys()         Object.keys()是ES5新增的一

    2024年02月16日
    浏览(48)
  • JS中遍历对象的方法讲解

    在JavaScript中,有几种常用的方法可以用来遍历对象: 使用for…in循环可以遍历一个对象中的所有可枚举属性。它会将属性名逐个赋值给循环变量,并执行循环体内的代码。 例如: for…in循环会遍历对象自身的可枚举属性以及继承的可枚举属性。如果只想遍历对象自身的属性

    2024年02月09日
    浏览(33)
  • 【前端|Javascript第5篇】全网最详细的JS的内置对象文章!

    前言 在当今数字时代,前端技术正日益成为塑造用户体验的关键。我们在开发中需要用到很多js的内置对象的一些属性来帮助我们更快速的进行开发。或许你是刚踏入前端领域的小白,或者是希望深入了解内置对象的开发者,不论你的经验如何,本篇博客都将给你详细的讲解

    2024年02月12日
    浏览(114)
  • JavaScript—数据类型、对象与构造方法

    JavaScript(简称“JS”) 是一种具有函数优先的轻量级,解释型或即时编译型的编程语言。JavaScript 基于原型编程、多范式的动态脚本语言,并且支持面向对象、命令式、声明式、函数式编程范式。 (1)脚本语言。js不编译,直接解释执行 (2)基于对象。JavaScript是一种基于对象的

    2024年02月10日
    浏览(39)
  • JavaScript -- Map对象及常用方法介绍

    Map用来存储键值对结构的数据**(key-value)** Object中存储的数据就可以认为是一种 键值对结构 Map和Object的主要区别: Object中的属性名只能是 字符串或符号 ,如果传递了一个其他类型的属性名,JS解释器会自动将其 转换为字符串 Map中任何类型的值都可以成为数据的key map.si

    2024年02月10日
    浏览(53)
  • 【JavaScript】对象 ② ( 对象使用 | 调用对象属性 | 调用对象方法 | 变量与属性区别 | 函数与方法区别 )

    使用字面量创建对象要点 : 在上一篇博客 【JavaScript】对象 ① ( 对象概念 | 对象使用场景 | 使用字面量创建对象 | 空对象字面量 | 小括号 / 中括号 / 大括号 作用 ) 中 , 介绍了 使用 字面量 创建对象 , 有如下要点 : 键值对 : 对象字面量 中的 属性 和 方法 都是以 \\\" 键值对 \\\" 的形

    2024年04月14日
    浏览(54)
  • JavaScript判断对象是否为空对象的几种方法

    目录 1、空对象对应的字符串为 \\\"{}\\\" 2、for in 3、jquery 的 isEmptyObject()方法 4、Object.getOwnPropertyNames() 5、ES6 的 Object.keys() JSON.stringify()扩展 1、第一大特性 小结 2、第二大特性 3、第三大特性 4、第四大特性 5、第五大特性 6、第六大特性 7、第七大特性 8、第八大特性 var data = {}; v

    2024年01月16日
    浏览(88)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包