Comments (9)
说实话,感觉考这些真的很无聊。。学js学得都陷在语法的泥潭里了,像极了大学时期末考试C语言i++、++i之类的。。
from fe-interview.
加了默认值,则转为严格模式(其实也可以使用 "use strict" 转),这时候参数(a、b、c)与 arguments 没有绑定关系,所以修改 arguments 不会影响到参数(a、b、c)的值,修改参数(a、b、c)也不会影响到 arguments。
不加默认值,则为非严格模式,结果和上面的相反。
from fe-interview.
c会变成10啊,解析的什么东东
是arguments 中 c 的值,function a(a, b, c = 3) 这里的c,因为 a 函数加了默认值,所以就按 ES 的方式解析,函数中的参数就不会变了
function side(arr) {
arr[0] = arr[2];
}
function a(a, b, c = 3) {
c = 10;
console.log(arguments);
side(arguments); // 这里 a,c的值不管怎么改变都是不会改变的
return a + b + c;
}
a(1, 1, 1); //12
但是,如果是
function side(arr) {
arr[0] = arr[2];
}
function a(a, b, c) {
c = 10;
console.log(arguments);
side(arguments); // 这里 a,c的值不管怎么改变都是不会改变的
return a + b + c;
}
a(1, 1, 1); // 21
from fe-interview.
说实话,感觉考这些真的很无聊。。学js学得都陷在语法的泥潭里了,像极了大学时期末考试C语言i++、++i之类的。。
JavaScript 因为一些历史原因,它的设计很糟糕
但是现在制定标准委员会确实在创造新的特性和语法,来弥补过去糟糕设计带来的糟糕的使用
也鼓励大家使用新特性和语法去替代旧的糟糕的特性和语法
有了 good parts 就用新东西就好了,老的糟糕设计要保留是为了兼容历史包袱,大家也不该继续用了
但是有些考题还考这些「历史包袱」就很没有意义的,一点价值都没有,挺不能理解的
这些东西不该成为,常驻于我们 JavaScript 编程思维模型中的常客,因为这些东西挺扰乱思路的。如果真的在开发中遇到这种,超低频率出现的问题,也应该当时找资料去解决它
from fe-interview.
c会变成10啊,解析的什么东东
是arguments 中 c 的值,function a(a, b, c = 3) 这里的c,因为 a 函数加了默认值,所以就按 ES 的方式解析,函数中的参数就不会变了
function side(arr) { arr[0] = arr[2]; } function a(a, b, c = 3) { c = 10; console.log(arguments); side(arguments); // 这里 a,c的值不管怎么改变都是不会改变的 return a + b + c; } a(1, 1, 1); //12但是,如果是
function side(arr) { arr[0] = arr[2]; } function a(a, b, c) { c = 10; console.log(arguments); side(arguments); // 这里 a,c的值不管怎么改变都是不会改变的 return a + b + c; } a(1, 1, 1); // 21
在es5的非严格模式下,因为数组索引对应了数据属性,所以会互相联动的,也就是c和arguments[2]绑定了;而在严格模式下则是简单拷贝。es6是简单拷贝,所以c的值不会因为argument的变化而改变
from fe-interview.
答案
12
解析
arguments 中 c 的值还是 1 不会变成 10,
因为 a 函数加了默认值,就按 ES 的方式解析,ES6 是有块级作用域的,所以 c 的值是不会改变的
from fe-interview.
c会变成10啊,解析的什么东东
from fe-interview.
当设置了解构赋值、默认值、剩余运算符 arguments的值不会变
from fe-interview.
c会变成10啊,解析的什么东东
首先,c会有一个默认值3,调用a函数传递了三个1,此时a函数三个变量都为1,此时执行a函数第一行代码,将形参c赋值为10,调用side将当前函数args数组传递过去,改变该数组的第一项,并不会对args会有影响,所以c还是10,所以最终是12
from fe-interview.
Related Issues (20)
- Day378:说一下什么是 Http 协议无状态?怎么解决 Http 协议无状态?
- Day379:如果让你来实现一个前端监控系统,应该考虑什么?如何去实现?
- Day380:实现一个系统,统计前端页面性能、页面 JS 报错、用户操作行为、PV/UV、用户设备等消息,并进行必要的监控报警。方案如何设计,用什么技术点,什么样的系统架构,难点会在哪里? HOT 3
- Day381:说一下 JavaScript 严格模式下有哪些不同?
- Day382:说一下 setTimeout 和 setInterval 的区别,包含内存方面的分析?
- Day383:说下 React 的 useEffect、useCallback、useMemo HOT 2
- Day384:JavaScript 中如何实现一个类?怎么实例化这个类? HOT 2
- Day385:在一个 DOM 上同时绑定两个点击事件:一个用捕获,一个用冒泡。事件会执行几次?先执行冒泡还是捕获? HOT 9
- Day386:写一个通用的事件侦听器函数 HOT 3
- 定时函数 HOT 1
- 小程序不维护了吗? HOT 10
- --
- 小程序里面的内容还有其他地方能学习吗
- 求小程序哇!!不然学习效率太低了 HOT 1
- 现在还能在哪里看题目答案吗?小程序关闭了😭😭 HOT 1
- #### 1)为什么会有Event Loop
- > > > @Genzhen 请教一下大佬,如果在render里面结构赋值也会影响性能吗?比如 const { page, size } = this.state这种的? HOT 1
- 考察原型链
- issue路径错误,提不了pr,可见下图
- vue中&nextTick的原理
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from fe-interview.