stackoverflow 热门前端问题整理翻译
背景
虽然国内有掘金这样的技术社区可以获取一些学习资源,但是像stackoverflow这样的以技术问答形式分享的却比较少(我知道有那个,但是...)。私认为在学习过程中,如果能够针对一个问题来着手,一直深入下去,可以让你这个知识点掌握的更加深刻。
虽然经过了一番筛选后,整理的很多问题,现在可能看起来仍然比较过时,解答也没有一些现成的前端面试答案的资料看起来更爽更舒服。
但是在整理翻译的过程中,还是会有一些让人觉得 “原来还能这样” 的深刻体会
然后,这些问题之所以之所以票数比较高,除了问题比较经典,时间久远积累的原因之外,更多的是因为很多答疑者们,在提供解决方案的同时,还能集思广益,引发更多角度的思考:
- 比如通过ECMA标准规范,对问题进行刨根剖底:
this 的运行原理?
- 比如针对 "老生常谈" 的问题,进行其他角度的思考:
在 JavaScript 中如使字符串的第一个字母大写(含国际化方案讨论)?
- 还有一些可能目前热度不高,但是却令人茅塞顿开...
Javascript 在哪里为函数调用的结果分配内存?堆栈还是堆?
- 比如会将一些浅显易懂的解决方案背后的优缺点,进行一一对比:
在 JavaScript 中循环遍历数组
总之言而,就是在解决问题的同时,还能够引导大家对问题的背后原因多一些思考~
所以,我想对 stackoverflow 上 前端 相关(主要是JS,浏览器,框架,性能等)投票数较多且比较有意义的问题进行整理翻译!
短期目标,是先搜集整理翻译100个问题~
为了让 翻译 更有意义,给阅读者带来更有效的收获,会做一些额外加工:
例如,删除过时问题、问题分类、聚合答案、删除冗余内容、加上自己的验证结果、心得等等
由于筛选机制原因,票数最多的问题,一般提问时间也比较久远,对于一些已经明显过时的问题,不在进行翻译
一些有意义的经典问题,仍然进行翻译,大家也可以对此做个历史参考,但是随着ECMA标准的迭代,答案可能不一定准确了 ~
PS: 个人能力有限,也欢迎大家提PR帮我改进或者一起翻译。
阅读
目录
基础
- [“use strict” 在 JavaScript 中做了什么,背后的原因是什么?]
- [JavaScript 闭包是如何工作的?]
- [sleep() 的 JavaScript 版本是什么?]
- [如何测试一个空的 JavaScript 对象?]
- [检查 JavaScript 对象中是否存在某个键?]
- [在 JavaScript 中循环遍历数组]
- [在 JavaScript 中循环枚举对象]
- [为什么不能使用 “for...in” 进行数组迭代?]
- [怎么理解 JavaScript 中的 new ?]
- [在 JavaScript 中如何检测 "invalid date" 日期?]
- [在 JavaScript 中如何将十进制转换为十六进制?]
- [如何创建一个 [1,2,3,4,N...] 的数组?]
- [JavaScript是否有类似 range() 的方法,可以在边界内的生成一个范围?]
- [在JavaScript中把字符转换成ASCII编码?]
- [this 的运行原理?]
- todo ...
进阶
- [在 JavaScript 中如使字符串的第一个字母大写(含国际化方案讨论)?]
- [Javascript 在哪里为函数调用的结果分配内存?堆栈还是堆?]
- [什么时候应该使用encodeURI,而不是encodeURIComponent?]
- todo ...
Typescript
- [TypeScript是什么,为什么要用它来代替JavaScript?]
- [TypeScript中 接口(interface) 与 类型(type) 的区别是什么?]
- todo ...
React
- [React中 state 和 props 的区别是什么?]
- todo ...