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
相关推荐
普通网友几秒前
PHP语言的正则表达式
开发语言·后端·golang
黎雁·泠崖1 分钟前
Java常用类核心详解(七):正则表达式 Regex 从入门到实战
java·开发语言·正则表达式
简单Janeee6 分钟前
[Vue 3 从零到上线]-第四篇:组件化思维——把网页像积木一样拆解
javascript·vue.js·ecmascript
PingdiGuo_guo7 分钟前
C++数据类型、变量常量
开发语言·c++
多恩Stone1 小时前
【C++ debug】在 VS Code 中无 Attach 调试 Python 调用的 C++ 扩展
开发语言·c++·python
PingdiGuo_guo1 小时前
C++联合体详解!
开发语言·c++
Heo1 小时前
深入React19任务调度器Scheduler
前端·javascript·面试
boooooooom2 小时前
Vue3 nextTick 实现大变化:微任务优先,彻底搞懂渲染时机!
javascript·vue.js·面试
用户14436183400972 小时前
你不知道的JS上-(九)
前端·javascript
浅念-2 小时前
C++ 继承
开发语言·c++·经验分享·笔记·学习·算法·继承