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
相关推荐
前端无涯几秒前
深度解析:fetch 与 Promise 结合实战及面试重点
前端·javascript
风舞红枫3 分钟前
node代理vue打包后的文件,实现本地测试
前端·javascript·vue.js·node.js
Yanni4Night6 分钟前
使用URLPattern API构建自己的路由器 🛣️
前端·javascript
抹除不掉的轻狂丶11 分钟前
Java 日志框架完整指南:发展历史、核心组成与最佳实践
java·开发语言·python
lsx20240619 分钟前
Bootstrap5 按钮组
开发语言
全栈陈序员19 分钟前
Vue 实例挂载的过程是怎样的?
前端·javascript·vue.js·学习·前端框架
林涧泣22 分钟前
使用Java输出HelloWorld
java·开发语言
lsx20240626 分钟前
Perl 基础语法
开发语言
IT北辰36 分钟前
用 Python 自动解析药品规格并计算包装总容量 —— pandas + 正则实战
开发语言·python·pandas
资生算法程序员_畅想家_剑魔42 分钟前
Java常见技术分享-10-装饰器模式
java·开发语言·装饰器模式