0428 手打基础丸

手打基础丸 🧆 => 精选基础知识,经过多道工序精心制作而成,口感鲜嫩多汁。一口咬下,香气四溢,加上传统前端风味,令人回味无穷...... 助力食用者厚积薄发,夯实根基进阶上层。

JS如何获取对象非原型链上的属性?

Object方法

css 复制代码
const obj1={
  attr: 'myName',
  [Symbol('symattr')]: 22
}
//获取所有自身属性(不包括symbol):Object.getOwnPropertyNames
console.log(Object.getOwnPropertyNames(obj1)) // ['attr']
//获取所有可枚举自身属性:Object.keys
console.log(Object.keys(obj1)) // ['attr']
//获取所有Symbol类型自身属性:Object.getOwnPropertySymbols
console.log(Object.getOwnPropertyNames(obj1)) // [Symbol(symattr)]
//获取属性完整信息:Object.getOwnPropertyDescriptor
console.log(Object.getOwnPropertyDescriptor(obj1))
// {name:{configurable:true, enumerable:true, value:"myname", writable: true}, Symbol('symattr'):{configurable:true, enumerable: true, value: 22, writable: true}}

查看对象是否具有指定属性:hasOwnProperty

arduino 复制代码
const  obj2={ name: 'myName' }
console.log(obj2.hasOwnProperty('name')) // true
console.log(obj2.hasOwnProperty('toString')) // true

还可以用for..in循环或者Object.entries(obj).forEach遍历自身属性

JS执行上下文?

摘自(segmentfault.com/a/119000004...

执行上下文简单来讲就是一段代码执行时所带的所有信息,每个任务压入执行栈中的一块所包含的所有内容。

全局执行上下文:任何不在函数内部的代码都在全局的上下文中

函数执行上下文:每次调用函数都会创建一个新的执行上下文

eval执行上下文:eval函数执行时创建的上下文

执行上下文生命周期:创建阶段--执行阶段--回收阶段

关于JS中的this指向问题?

全局上下文this指向全局对象,浏览器中指向window对象

函数调用中this指向全局对象或undefined(严格模式)

方法调用this指向调用该方法的对象

构造函数this指向新创建的实例对象

箭头函数没有自己的他this,继承他上层的this

相关推荐
cxyll12342 分钟前
从接口自动化测试框架设计到开发(三)主流程封装、返回数据写入excel
前端·python·excel
D11_3 分钟前
【React】JSX基础
前端·react.js·前端框架
Ynov22 分钟前
本地存储(Local Storage)与Cookie的深度对比
前端·javascript
卓伊凡24 分钟前
复杂项目即时通讯从android 5升级android x后遗症之解决报错#6 java.net.SocketException Software caused
前端·后端
鹏程十八少24 分钟前
4. Android FrameWork之 Binder总结,深入剖析 Android Binder:从 Java 到内核的完整通信图谱
前端
PineappleCoder26 分钟前
同源策略是啥?浏览器为啥拦我的跨域请求?(一)
前端·后端·node.js
遂心_27 分钟前
深入理解 requestAnimationFrame:打造流畅动画的利器
前端·javascript
晴空雨27 分钟前
Zustand vs Redux Toolkit:现代 React 状态管理深度对比
前端·react.js
文艺理科生29 分钟前
Nuxt 组件渲染进阶:服务端与客户端组件的协作艺术
前端·javascript·vue.js
Mintopia30 分钟前
Next 全栈开发:Prisma 的安装与配置指南 —— 从数据库魔法到代码现实
前端·javascript·next.js