当前位置: 首页 > news >正文

JS进阶-day1 作用域解构箭头函数

作用域

全局作用域——>尽量少使用,避免变量污染

局部作用域——>函数作用域、块级作用域

作用域链——>底层变量查找机制(先在当前函数作用域查找,如果找不到,就沿着作用域链向上级作用域查找,直到全局作用域)

闭包

概念:一个函数对周围状态的引用捆绑在一起,内层函数中访问到其外层函数的作用域

内存泄露:内存应该被回收却没有回收

闭包=内层函数+外层函数的变量

闭包的作用:

  1. 封闭数据,实现数据的私有,外部函数也可以访问函数内部的变量
  2. 闭包很有用,因为它允许将与其所操作的某些数据环境关联起来

闭包可能引起的内存泄露问题

function count() {let i = 0function fn() {i++console.log(`函数被调用了${i}次`)}return fn}const fun = count()

变量提升

使用var关键字声明变量会有变量提升,所有var声明的变量提升到 当前作用域的最前面

变量提升流程:

1.先把var变量提升到当前作用域于最前面

2.只提升变量声明,不提升变量赋值

3.然后依次执行代码

    function fn() {console.log(num)var num = 10}fn()

不建议使用var声明变量

函数提升

会把所有函数声明提升到当前作用域前面

只提升声明,不提升函数调用

fn()
function fn() {console.log('函数提升')
}//函数提升后
/*function fn() {console.log('函数提升')
}
fn()*/
fun()
var fun = function () {console.log('函数表达式')
}// 函数表达式 必须先声明和赋值, 后调用 否则 报

 函数动态参数

arguments 动态参数 只存在 函数里面
是伪数组 里面存储的是传递过来的实参

function getsum() {let sum = 0for (let i = 0; i < argumrnts.length; i++) {sum += arguments[i]}console.log(sum)
}
getsum(5, 6, 7)

箭头函数

//标准格式
const fn = () => {}
fn()//写在一行上,可省略大括号
const fn = () => console.log(11)
fn() //11//传参只有一个数时,可省略括号
const fn = e => console.log(e)
fn(1) //1//只有一行代码时,可省略return
const fn = e => e + e
console.log(fn(1))  //2//箭头函数可以直接返回一个对象
const fn = (uname) => ({name: uname})
console.log(fn('陈xx'))

普通函数有arguements动态参数

箭头函数没有arguements动态参数,但可以使用剩余参数(...arr)

在开发中【使用箭头函数前需要考虑函数中 this 的值】,事件回调函数使用箭头函数时,this 为全局的 window,因此 DOM事件回调函数为了简便,还是不太推荐使用箭头函数

对象结构

const goods = [{goodsName: '小米',price: 1999}
]
const [{goodsName, price}] = goods
console.log(goodsName)
console.log(price)

多级对象结构

const pig = {name: '佩奇',family: {mother: '猪妈妈',father: '猪爸爸',sister: '乔治'},age: 6
}
// 多级对象解构
const { name, family: { mother, father, sister },age } = pig
console.log(name)
console.log(mother)
console.log(father)
console.log(sister)
console.log(age)

http://www.dtcms.com/a/278059.html

相关文章:

  • Spring AI 项目实战(十六):Spring Boot + AI + 通义万相图像生成工具全栈项目实战(附完整源码)
  • NO.5数据结构串和KMP算法|字符串匹配|主串与模式串|KMP|失配分析|next表
  • pthread_mutex_unlock函数的概念和用法
  • 大规模电商系统分库分表实战经验分享
  • NFSV4锁机制(三)
  • 编程技术杂谈2.0
  • DVWA靶场通关笔记-XSS DOM(High级别)
  • 垃圾收集器-Serial Old
  • CVE-2022-0609
  • vue2入门(1)vue核心语法详解复习笔记
  • 【开源项目】网络诊断告别命令行!NetSonar:开源多协议网络诊断利器
  • 1.1.1+1.1.3 操作系统的概念、功能
  • c++无锁队列moodycamel::ConcurrentQueue测试结果
  • 在高并发场景下,仅依赖数据库机制(如行锁、版本控制)无法完全避免数据异常的问题
  • Sping AI Alibaba
  • 第11章 AB实验评估指标体系
  • Soul方程式:Z世代背景下兴趣社交平台的商业模式解析
  • Java行业前景如何?零基础又该如何去学Java?
  • 深入理解 RocketMQ:生产者详解
  • 并行并发丨C++ 协程、现场池 学习笔记
  • 闲庭信步使用图像验证平台加速FPGA的开发:第十三课——图像浮雕效果的FPGA实现
  • 语言模型常用的激活函数(Sigmoid ,GeLU ,SwiGLU,GLU,SiLU,Swish)
  • 算法-汽水瓶兑换
  • Spring AI 项目实战(十七):Spring Boot + AI + 通义千问星辰航空智能机票预订系统(附完整源码)
  • 【webrtc】gcc当前可用码率3:x264响应码率改变
  • 系规备考论文:论IT服务部署实施方法
  • 西藏氆氇新生:牦牛绒混搭液态金属的先锋尝试
  • 分布式锁踩坑记:当“防重“变成了“重复“
  • JAVA并发——什么是Java的原子性、可见性和有序性
  • Redis缓存设计与性能优化指南