JavaScript function默认参数赋值前后顺序差异

1、(num1,num2=num1) 当传值仅传一个参数时,先给到第一个参数即num1,num1再赋值给num2,

复制代码
function sum(num1, num2 = num1) {
  console.log(num1 + num2)
}
sum(10)//20
sum(10,3)//13

2、(t2=t1,t1) 当传值仅有一个参数时,先给到第一个参数即t2,可t1参数的值尚未初始化,所以t1也就是undefined

复制代码
function total(t2 = t1,t1) {
  console.log(t1 + t2)
}
total(10)//NaN  参数的值尚未初始化,导致的错误
total(10,3)//13

容易看错的默认赋值情况:(如果调用传参有值,默认值是无效的)

复制代码
function test(m = n, n = 2) {
    console.log(m, n)
}
test() // 报错 Uncaught ReferenceError: Cannot access 'n' before initialization
test(3) // 3 2
test(3, 4) // 3 4
相关推荐
springXu几秒前
windows arm64上的VS CODE的GoLang环境的搭建
开发语言·后端·golang
ChoSeitaku1 分钟前
08_抽象_接口_final关键字_多态
java·开发语言
程序员zgh3 分钟前
AUTOSAR CP 之 配置、开发流程、工具链 解析
c语言·开发语言·c++·系统架构·汽车
xyq20243 分钟前
Bootstrap4 提示框
开发语言
yqcoder5 分钟前
JavaScript 的速度秘密:深入理解 JIT (即时编译)
开发语言·javascript·ecmascript
西洼工作室10 分钟前
UniApp开发全攻略:从生命周期到路由传值
前端·javascript·uni-app
吴声子夜歌16 分钟前
Java——动态代理
java·开发语言·代理模式
存在morning17 分钟前
【GO语言开发实践】一 GO 语法快速上手
开发语言·python·golang
晨曦中的暮雨17 分钟前
Python 并发模型理解:GIL、线程、async 到底是什么关系
开发语言·python
星恒随风17 分钟前
四天学完前端基础三件套(JavaScript webAPI篇)
开发语言·前端·javascript