ES6之函数的扩展

函数的扩展

文章目录

1:与解构赋值默认值结合使用

javascript 复制代码
function fun1 ({a,b=10}){
    console.log(a,b)
}
fun1({}) // 0,10
fun1({a:1,b:5}) // 1,5
// 应该对象的的形式,函数内部才能解构取值
fun1()  // 错误

2:参数默认值空对象

提供一个参数默认值空对象

2.1 案例一

当函数内部进行解构时,默认值为{}空对象,a为undefined,b为默认值

javascript 复制代码
function fun2 ({a,b=2} = {}){
    console.log(a,b)
}
fun2()  // undefined,2

2.2 案例二

javascript 复制代码
function fun3 (url,{body='',methods='get',header=''}){
    console.log(url,methods)
}

第二个参数转一个空对象,函数默认值 get 生效

javascript 复制代码
fun3('http://localhost:3000/admin/icmAudit/findPage',{}) // http://localhost:3000/admin/icmAudit/findPage,get

在没有传第二个参数时,函数也没有默认第二个参数时,会报错

javascript 复制代码
fun3('http://localhost:3000/admin/icmAudit/findPage') // Uncaught TypeError: Cannot read properties of undefined (reading 'body')

2.3 案例三

优化:函数入参第二个参数添加默认值{}

javascript 复制代码
function fun4 (url,{body='',methods='post',header=''} = {}){
    console.log(url,methods)
}

在没有传第二个参数时,函数第二个入参有默认值,正常打印

javascript 复制代码
fun4('http://localhost:3000/admin/icmAudit/findPage')   // http://localhost:3000/admin/icmAudit/findPage,get

2.4 案例四

函数参数默认值应该放在末尾,(如果不是末尾,省略会报错)

javascript 复制代码
function fu2 (a=1,b){
    console.log(a,b)
}
fu2(10,8) // 10,8
fu2(,6) // Uncaught SyntaxError: Unexpected token ',' 

3:undefined null参数默认值的区别

javascript 复制代码
function fu3(a=2,b=3){
    console.log(a,b)
}

测试默认值传undefined和null的区别

undefined 会触发参数默认值,null没有触发参数默认值

javascript 复制代码
fu3(undefined,null)  // 2 null  

4:函数length

函数length将返回没有指定默认参数的length

javascript 复制代码
console.log((function(a){}).length) // 1
console.log((function(a,b=12){}).length) // 1
console.log(function(a,b,e=10){}.length) // 2  

默认参数后面的数据不计入length,所以默认参数应放在函数入参末尾,避免不必要错误

javascript 复制代码
console.log(function(a,b=6,e){}.length) // 1  

5:作用域

javascript 复制代码
let x1 = 12
function f4(x1,b=x1) {
    console.log(b)
}
f4(6) // 6

5.1 全局变量

这时候全局变量a41没有使用到,使用的是局部变量

第一个参数a41=10,第二个参数a41取第一个参数的值,那么b等于10,输出10

javascript 复制代码
let a41 = 10
function f41(a41,b=a41) {
    console.log(b)
}

f41(10) // 10

5.2:局部变量

javascript 复制代码
let a42 = 8
function f42(b=a42) {
    let a42 = 12
    console.log(b)
}

f42() // 输出8

a42局部变量不会生效,函数括号里面的b=a42形成一个单独作用域

  • 步骤一:f42(b=a42),b取a42值,a42是变量,取不到;
  • 步骤二:a42先在函数括号里面这个单独作用域中进行查找,查找不到向上查找,获取的是全局变量的值,
  • 步骤三:这时候b再取a42的值,往下进入函数内部。
  • 步骤三:这时候函数内部的b的值就是8了

6:暂时性死区

javascript 复制代码
let a43 = 10
function f43(a43=a43) {
}
f43()  //   Cannot access 'a43' before initialization

函数括号中let a43 = a43,代码暂时性死区引起的错误

7:函数作为参数

7.1 案例一

javascript 复制代码
let fu44 = 12
function f44(fun = () => fu44) {
    let fu44 = 36
    console.log(fun())
}
f44() // 12

和变量作为参数,方法是相同的

7.2 案例二

复杂的函数参数

javascript 复制代码
var fu46 = 1
function f46(fu46,b = function () { fu46 = 2 }) {
    var fu46 = 12  // 这里的var 加上和去除,最后打印的fu46值都不一样,作用域不同
    b()
    console.log('fu46:',fu46)
}
f46() // 12
console.log('global fu46:',fu46) // 1

8:应用

8.1 参数默认值不可以省略

javascript 复制代码
function a11 () {
    throw new Error('缺少 paratment')
}

function a12 ( arr = a11()) {
    return arr
}

a12() // Uncaught Error: 缺少 paratment

8.2 参数默认值可以省略

javascript 复制代码
function a13 (fun1 = undefined) {
    console.log(1111)
} 
a13() // 1111
相关推荐
想要飞翔的pig4 分钟前
uniapp+vue3页面滚动加载数据
前端·vue.js·uni-app
HarryHY4 分钟前
git提交库常用词
前端
SoraLuna4 分钟前
「Mac畅玩AIGC与多模态41」开发篇36 - 用 ArkTS 构建聚合搜索前端页面
前端·macos·aigc
霸王蟹12 分钟前
React Fiber 架构深度解析:时间切片与性能优化的核心引擎
前端·笔记·react.js·性能优化·架构·前端框架
benben04412 分钟前
Unity3D仿星露谷物语开发44之收集农作物
前端·游戏·unity·游戏引擎
会功夫的李白16 分钟前
uniapp自动构建pages.json的vite插件
前端·uni-app·vite
一口一个橘子34 分钟前
[ctfshow web入门] web77
前端·web安全·网络安全
yyywoaini~1 小时前
wordcount程序
前端·javascript·ajax
Yvonne爱编码1 小时前
CSS- 4.2 相对定位(position: relative)
前端·css·状态模式·html5·hbuilder
白小白灬1 小时前
Vue主题色切换实现方案(CSS 变量 + 类名切换)
前端·css·vue.js