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

相关推荐
10年前端老司机2 小时前
什么!纯前端也能识别图片中的文案、还支持100多个国家的语言
前端·javascript·vue.js
摸鱼仙人~2 小时前
React 性能优化实战指南:从理论到实践的完整攻略
前端·react.js·性能优化
程序员阿超的博客3 小时前
React动态渲染:如何用map循环渲染一个列表(List)
前端·react.js·前端框架
magic 2453 小时前
模拟 AJAX 提交 form 表单及请求头设置详解
前端·javascript·ajax
小小小小宇7 小时前
前端 Service Worker
前端
只喜欢赚钱的棉花没有糖8 小时前
http的缓存问题
前端·javascript·http
小小小小宇8 小时前
请求竞态问题统一封装
前端
loriloy8 小时前
前端资源帖
前端
源码超级联盟8 小时前
display的block和inline-block有什么区别
前端
GISer_Jing8 小时前
前端构建工具(Webpack\Vite\esbuild\Rspack)拆包能力深度解析
前端·webpack·node.js