每个程序员都需要学习 JavaScript 的7个理由小结


Posted in Javascript onSeptember 03, 2016

最近在和招聘经理交流现在找一个好的程序员有多难的时候,我渐渐意识到了现在编程语言越来越倾重于JavaScript。Web开发人员尤其如此。所以,如果你是一个程序员,那么你应该去学习JavaScript。

需求

我之所以这样说的主要原因是,随着JavaScript的日渐成熟,以及Node.js方案变得越来越可行,我们对JavaScript程序员的需求正在持续增长。 JavaScript在需求比例上已经超过了C#,仅屈居于Java之下。如果你看看GitHub上可行的项目,你会发现JavaScript出现得越来越多,甚至领先于Java和C#。最后,再看看StackOverflow,你会发现JavaScript也处于顶层活跃中。

更好的薪酬

根据SitePoint,JavaScript的薪资要高于C#。当然,虽然现在Java的薪水还是比JavaScript高上那么一点。但随着JavaScript需求的增长,你可以预见它的薪酬肯定会提高。

在Gooroo,关于薪酬VS需求呈现的画面略有不同。虽然我们对JavaScript的需求是显而易见的,但是很明显,几种需求较小的语言反而薪酬更高。我怀疑这是因为许多公司仍然认为JavaScript是任何一个程序员都会用的语言。但是,当他们认识到“任何一个程序员都会JavaScript”,实际上是“任何一个程序员只会写蹩脚的JavaScript代码”的时候,也是他们经历惨痛教训的时候。然后需要真正的JavaScript程序员进入清理留下的烂摊子。

在StackOverflow,我们看到了一份非常详细的关于开发人员在过去三年时间中的归类。当你最后看到“使用的技术”部分的时候,我们发现,如果你称自己为JavaScript程序员(这里假设是在客户端),那么你得到的报酬虽然比C#程序员低,但会比Java程序员要好,但如果你说自己是一个Node.js程序员(全JavaScript),那么你能拿到第二高的工资。唯一比Node.js还高的是Objective-C(我假设以后会是,Swift)。

JavaScript正日趋成熟

新的JavaScript标准每年都会发布,而且现在很明显,被添加到JavaScript的语法糖 (Syntactic Sugar)的数量每年都在增加。其中一个我期待的功能是,能在我的JavaScript代码中使用异步和await关键字,以消除回调地狱(callback hell)。

你越早开始学习JavaScript,那么学习起来就越容易。所有的改变都是循序渐进的,就像浏览器正在不断地改进处理JavaScript代码的能力。可以预见在不久的将来,浏览器不仅可以缓存JavaScript文件,还可以缓存JavaScript文件的编译版本。

JavaScript程序员更能被委以重任

大概在一年前我和我的一个老朋友聊天的时候,他提到,他是他们小组(约20个程序员)唯一一个用这样的方式写JavaScript以消除变量对全局范围的污染的程序员。这只是最简单的例子。很多人称自己为JavaScript程序员,却不知道这些基本知识。所以,JavaScript大有可为。

而且不要忘了,现在很多支持性能分析和内存泄漏的工具才刚处于起步阶段。如果你现在就掌握了这些技能,那么将来肯定可以更好地推销自己。

如果你对这一类东西感兴趣,那么可以阅读PluralSight上的一些课程。只要搜索“JavaScript profiling”即可。

日趋完善的框架

Angular的新版本正在开发中,而且还有Aurelia作为候选。商业产品如Scencha的EXTjs。还有用于服务器端编程的Node.js。等等等等。用JavaScript开发实际的应用程序并不太难。我敢保证,如果我愿意的话,我完全可以只用JavaScript来写一个可以运行的桌面应用程序。嘿嘿。

JavaScript无处不在

JavaScript可运行在所有主要平台的所有主流浏览器上,也可运行在每一个主流操作系统的服务器端上。现如今我们在为网站写任何一个主要功能的时候都需要有懂能够用JavaScript写前端的开发人员。而后端代码是用什么编写的则无所谓——不管是Java,PHP,.NET,Node.js还是其他——但是客户端就一定需要一个JavaScript开发人员。事实上,现在很多开发人员依然没有认识到JavaScript有多么强大。不知道正在阅读的你是否也是这些井底之蛙的一员。如果你确实是一个了不起的JavaScript程序员,那么基本上所有有关于服务器端平台的工作都能够胜任。如果再了解这些平台基本上就可以上任了。

JavaScript是一种编译语言

这也许会吓你一跳,从技术上说,JavaScript是一种编译语言。这有两个含义。首先,一旦代码被编译,它的运行速度或许就能媲美于任何其他可执行文件。其次,为JavaScript写工具在技术上是可行,并且将会创建一个不必每次加载代码到内存中时就重新编译的二进制文件。

你有什么感想?

当然,以上都是我的观点。你有什么感想吗?欢迎不吝赐教。

英文原文:7 Reasons Every Programmer Needs to Learn JavaScript
翻译作者:码农网 ? 小峰

Javascript 相关文章推荐
用js模拟JQuery的show与hide动画函数代码
Sep 20 Javascript
javascript 单例/单体模式(Singleton)
Apr 07 Javascript
jquery利用拖拽方式在图片上添加热链接
Nov 24 Javascript
学习JavaScript设计模式(单例模式)
Nov 26 Javascript
学习JavaScript鼠标响应事件
Dec 25 Javascript
AngularJS 实现点击按钮获取验证码功能实例代码
Jul 13 Javascript
JS按钮闪烁功能的实现代码
Jul 21 Javascript
vue弹窗组件使用方法
Apr 28 Javascript
js中Object.defineProperty()方法的不详解
Jul 09 Javascript
vue项目部署到Apache服务器中遇到的问题解决
Aug 24 Javascript
vue实现的上拉加载更多数据/分页功能示例
May 25 Javascript
如何在vue中使用kindeditor富文本编辑器
Dec 19 Vue.js
JavaScript 冒泡排序和选择排序的实现代码
Sep 03 #Javascript
浅析$(function) ready和onload 的区别
Sep 03 #Javascript
详解Javascript中prototype属性(推荐)
Sep 03 #Javascript
jQuery基本选择器之标签名选择器
Sep 03 #Javascript
基于JS实现回到页面顶部的五种写法(从实现到增强)
Sep 03 #Javascript
jQuery dataTables与jQuery UI 对话框dialog的使用教程
Sep 02 #Javascript
AngularJs  unit-testing(单元测试)详解
Sep 02 #Javascript
You might like
PHP函数extension_loaded()用法实例
2015/01/19 PHP
php获取微信共享收货地址的方法
2017/12/21 PHP
OfflineSave离线保存代码再次发布使用说明
2007/05/23 Javascript
Js sort排序使用方法
2011/10/17 Javascript
javascript在IE下trim函数无法使用的解决方法
2014/09/12 Javascript
Bootstrap每天必学之导航
2015/11/26 Javascript
基于JavaScript实现回到页面顶部动画代码
2016/05/24 Javascript
功能强大的Bootstrap效果展示(二)
2016/08/03 Javascript
详解handlebars+require基本使用方法
2016/12/21 Javascript
js正则表达式最长匹配(贪婪匹配)和最短匹配(懒惰匹配)用法分析
2016/12/27 Javascript
JAVA中截取字符串substring用法详解
2017/04/14 Javascript
WebSocket实现简单客服聊天系统
2017/05/12 Javascript
React进阶学习之组件的解耦之道
2017/08/07 Javascript
vue表单绑定实现多选框和下拉列表的实例
2017/08/12 Javascript
mint-ui的search组件在键盘显示搜索按钮的实现方法
2017/10/27 Javascript
jQuery常见的遍历DOM操作详解
2018/09/05 jQuery
layui默认选中table的CheckBox复选框方法
2019/09/19 Javascript
微信小程序实现上拉加载功能
2019/11/20 Javascript
Vue的状态管理vuex使用方法详解
2020/02/05 Javascript
vue实现分页的三种效果
2020/06/23 Javascript
jquery实现拖拽添加元素功能
2020/12/01 jQuery
element-ui 弹窗组件封装的步骤
2021/01/22 Javascript
[43:03]LGD vs Newbee 2019国际邀请赛小组赛 BO2 第一场 8.16
2019/08/19 DOTA
Python实现设置windows桌面壁纸代码分享
2015/03/28 Python
调试Python程序代码的几种方法总结
2015/04/28 Python
python自制包并用pip免提交到pypi仅安装到本机【推荐】
2019/06/03 Python
Django 实现前端图片压缩功能的方法
2019/08/07 Python
Python简易版图书管理系统
2019/08/12 Python
python+pygame实现坦克大战
2019/09/10 Python
在pycharm中debug 实时查看数据操作(交互式)
2020/06/09 Python
亚马逊海外购:亚马逊美国、英国、日本、德国直邮
2021/03/18 全球购物
Linux中如何用命令创建目录
2016/12/02 面试题
青年标兵事迹材料
2014/08/16 职场文书
2016七夕情人节广告语
2016/01/28 职场文书
会议开幕致辞怎么写
2016/03/03 职场文书
使用Html+Css实现简易导航栏功能(导航栏遇到鼠标切换背景颜色)
2021/04/07 HTML / CSS