首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

【JavaScript】对象 ⑤ ( 遍历对象 | for…in 循环 遍历对象 | Object.keys() 遍历对象 的 属性名称 | Object.entries() 遍历对象属性键值对 )

可以使用如下几种方法 : 使用 for…in 循环 遍历对象 使用 Object.keys() 遍历对象 的 属性名称 使用 Object.values() 遍历对象 的 属性值 使用 Object.entries...() 遍历对象 的 属性名称 + 属性值 键值对组合 ; 二、遍历对象 1、使用 for…in 循环 遍历对象 for…in 循环 既可以用于遍历数组 , 又可以用于遍历对象的可枚举属性 ; 代码示例...() 遍历对象 的 属性名称 调用 Object.keys() 方法 可以返回一个表示 给定对象的所有 可枚举属性 的 字符串数组 , 然后 使用 forEach 数组的遍历方法 来遍历这些属性 ; 代码示例...() 遍历对象 的 属性值 在 JavaScript 中 , 调用 Object.values() 方法返回一个数组 , 数组元素是在给定对象上找到的可枚举属性值 , 然后使用数组的遍历方法来遍历这些值...() 遍历对象 的 属性名称 + 属性值 键值对组合 在 JavaScript 中 , 调用 Object.entries() 方法 可以返回 给定对象 自身可枚举属性的 键值对数组 ; 代码示例 :

18610

JS篇(021)-for in、Object.keys和Object.getOwnPropertyNames对属性遍历有什么区别

答案: * for in 会遍历自身及原型链上的可枚举属性 * Object. keys 会将对象自身的可枚举属性的 key 输出 * Object. getOwnPropertyNames会将自身所有的属性的...key 输出 解析: ECMAScript 将对象的属性分为两种:数据属性和访问器属性。...enumerable: true, configurable: true } }); // parent继承自Object.prototype,有一个可枚举的属性a(enumerable.... keys console.log(Object.keys(child)); // ["b"] // Object.keys 会将对象自身的可枚举属性的key输出 3、Object. getOwnPropertyNames...console.log(Object.getOwnPropertyNames(child)); // ["b","c"] // 会将自身所有的属性的key输出 [参与互动](https://github.com

1.2K20

JS 循环链表

循环链表的概念循环链表是一种链表的变体,其中链表中的最后一个节点指向链表的头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确的结束点。...灵活性:由于循环链表是循环的,因此可以在任意位置插入或删除节点,而无需修改其他节点的指针。这使得循环链表在某些场景下更加灵活和高效,例如实现循环列表、轮播图等。...场景应用:循环链表常用于需要循环遍历的场景。例如,在游戏开发中,可以使用循环链表来实现循环列表,遍历玩家角色队列;在轮播图或循环播放的场景中,可以使用循环链表来管理展示内容的顺序。...实现一个循环列表在 JavaScript 中,循环链表是一种特殊的链表结构,其中最后一个节点指向头节点,形成一个循环。这种数据结构可以用于处理需要连续循环遍历的场景。...list.append(2);list.append(3);list.traverse(); // 输出: 1 2 3在上面的示例中,我们首先定义了 Node 类作为链表节点的模板,包含一个 data 属性和一个

11810

js事件循环

首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器的js是单线程的,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好的处理异步请求,那么到底是为什么呢?...我们先来看一张图(这张图来自于http://www.zcfy.cc/article/node-js-at-scale-understanding-the-node-js-event-loop-risingstack...从上图我们可以看出,js主线程它是有一个执行栈的,所有的js代码都会在执行栈里运行。...原因:因为一开始js主线程中跑的任务就是macrotask任务,而根据事件循环的流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程的代码后,它就去从microtask队列里取队首任务来执行..., 以及借鉴了其他优秀文章 参考: http://www.zcfy.cc/article/node-js-at-scale-understanding-the-node-js-event-loop-risingstack

18.7K41

这次彻底理解了Object这个属性

默认情况下,我们添加到对象上的属性都是可枚举的,这样的话我们就可以使用for-in循环遍历它们。...:' + propertyName); console.log('属性值:' + obj[propertyName]); } for-in循环循环一次都会将一个属性名赋值给propertyName...如果我们只是想获取一个对象中的所有属性名,可以使用Object.keys()方法。该方法会以数组的形式返回所有的属性名。...如果我们向改变属性的特性,可以使用Object.defineProperty()方法。该方法接受3个参数:拥有被修改属性的对象、被修改的属性名、包含描述特性的对象。...Object.defineProperty(),定义多个属性使用的是Object.defineProperties(),这个方法接受2个参数,第一个是属性所属的对象,第二个是包含被定义属性的对象。

66020

JS 事件循环

: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...工作线程:也称幕后线程,这个线程可能存在于浏览器或js引擎内,与主线程是分开的,处理文件读取、网络请求等异步事件。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...在事件循环中,每进行一次循环操作称为tick,通过阅读规范可知,每一次 tick 的任务处理模型是比较复杂的,其关键的步骤可以总结如下: 在此次 tick 中选择最先进入队列的任务( oldest task...、process.nextTick(Node.js 环境) setTimeout/Promise 等API便是任务源,而进入任务队列的是由他们指定的具体执行任务。

15.4K10

面向对象中Object常用属性总结

学完Object属性,自己总结一些常用是Object常用属性Object.prototype:属性表示Object的原型对象。...Object.entries():方法返回一个给定对象自己的可枚举属性[key,value]对的数组,数组中键值对的排列顺序和使用 for-in 循环遍历该对象返回的顺序一致。...语法:Object.freeze(obj) obj:将要被冻结的对象 Object.getOwnPropertyDescriptor():方法返回指定对象上有一个自有属性对应的属性描述符(自有属性值的是直接...Object .keys():方法会返回一个由一个给定对象的自身可,枚举属性组成的数组,数组中属性名是排序顺序和使用for-in循环遍历该对象返回的顺序一致(两者的主要区别是一个for-in循环还会枚举其原型链上的属性...Object.values():方法返回一个给定对象自己的所有可枚举属性值的数组,值的顺序与使用for-in循环的顺序相同(区别在于for-in循环枚举原型链中的属性)。

88120

js Object.defineProperty()详解

要修改属性的默认特性,就必须使用 Object.defineProperty()方法 ;在了解Object.defineProperty()之前,需要先明白对象属性的一些特性,明白了这些特性之后,对Object.defineProperty...默认情况下,所有直接定义在对象上的属性的这个特性都是 true; Enumerable:表示属性是否可以通过 for-in 循环返回。...默认情况下,所有直接定义在对象上的属性的这个特性都是 true; Enumerable: 表示属性是否可以通过 for-in 循环返回。...(object,prop,descript) Object.defineProperty()接收三个参数: object: 要添加或者修改属性的目标对象; prop: 要定义或修改属性的名称; descript...}; Object.defineProperty(person, "age", { enumerable: false // 设置为false表示不能通过 for-in 循环返回 }); for

2.3K20

js对象属性

for in 循环遍历的属性 作为经常使用对象的我们,想必对这个语法并不陌生,虽然我们一般情况下很少直接这样用,因为更多业务场景下是属性的精准使用,不会通过循环的方式,原因有以下几个方面。...1 如果默认使用属性循环来展示数据,有很多不必要展示的数据都要过滤筛选掉,比较低效麻烦 2 属性循环访问不一定符合我们需要展示的顺序,这点才是致命的,导致我们在业务需要的时候更多的时候是固定顺序固定访问对象属性...(let p in zhangsan){ console.log(zhangsan.hasOwnProperty(p),`${p}:${zhangsan[p]}`) } 参考代码 codepen关于js...对象属性的案例 还什么方法可以拿到属性 没错,我们一般情况下使用for,in循环获取属性,但有些属性我们也希望得到。...对象自身可枚举,不含 Symbol 属性 Object.getOwnPropertyNames(obj) 返回一个数组,包含对象自身的所有属性(不含 Symbol 属性,但是包括不可枚举属性)的键名 对象自身

15.6K10

js nextSibling属性和previousSibling属性

1:nextSibling属性属性表示当前节点的下一个节点(其后的节点与当前节点同属一个级别);如果其后没有与其同级的节点,则返回null。...需要特别注意的是:该属性在不同的浏览器中的执行结果并不都相同,见下面例示: 先来看一个例子: <input id=“a4” type=“button” οnclick...opera和safari对nextSibling的处理方式与FF一致 2:previousSibling属性属性与nextSibling属性的作用正好相反。...3:通过nextSibling或者 previousSibling所获得的HTML标签元素对象的属性问题 一般先通过nextSibling.nodeName来获知其标签名,或者通过nextSibling.nodeType...如果该nextSibling.nodeName = #text,则通过nextSibling.nodeValue来获知其文本值;否则,可以通过nextSibling.innerHTML等其他常用标签元素属性来获取其属性

6.3K30
领券