每个程序员都需要学习 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 相关文章推荐
如何用javascript控制上传文件的大小
Oct 26 Javascript
Firefox中通过JavaScript复制数据到剪贴板(Copy to Clipboard 跨浏览器版)
Nov 22 Javascript
javascript设置金额样式转换保留两位小数示例代码
Dec 04 Javascript
使用JS实现jQuery的addClass, removeClass, hasClass函数功能
Oct 31 Javascript
Bootstrap中的fileinput 多图片上传及编辑功能
Sep 05 Javascript
JS html时钟制作代码分享
Mar 03 Javascript
浅谈vuex 闲置状态重置方案
Jan 04 Javascript
JS实现将二维数组转为json格式字符串操作示例
Jul 12 Javascript
详解@angular/cli 改变默认启动端口两种方式
Nov 29 Javascript
微信小程序获取用户信息及手机号(后端TP5.0)
Sep 12 Javascript
小程序实现图片预览裁剪插件
Nov 22 Javascript
原生js实现碰撞检测
Mar 12 Javascript
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
mysql limit查询优化分析
2008/11/12 PHP
解决PHP在DOS命令行下却无法链接MySQL的技术笔记
2010/12/29 PHP
Linux下手动编译安装PHP扩展的例子分享
2014/07/15 PHP
php生成RSS订阅的方法
2015/02/13 PHP
php实现向javascript传递数组的方法
2015/07/27 PHP
php静态成员方法和静态的成员属性的使用方法
2017/10/26 PHP
PHP设计模式之装饰器模式实例详解
2018/02/07 PHP
深入理解JavaScript作用域和作用域链
2011/10/21 Javascript
jquery属性选择器not has怎么写 行悬停高亮显示
2013/11/13 Javascript
两个数组去重的JS代码
2013/12/04 Javascript
jQuery取得select选择的文本与值的示例
2013/12/09 Javascript
JSONP跨域的原理解析及其实现介绍
2014/03/22 Javascript
实现图片预加载的三大方法及优缺点分析
2014/11/19 Javascript
浅谈重写window对象的方法
2014/12/29 Javascript
Javascript 链式作用域详细介绍
2017/02/23 Javascript
详解vue使用$http服务端收不到参数
2019/04/19 Javascript
[45:25]OG vs EG 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
Python转码问题的解决方法
2008/10/07 Python
详解Python中open()函数指定文件打开方式的用法
2016/06/04 Python
基于Python在MacOS上安装robotframework-ride
2018/12/28 Python
详解Python odoo中嵌入html简单的分页功能
2019/05/29 Python
解决安装python3.7.4报错Can''t connect to HTTPS URL because the SSL module is not available
2019/07/31 Python
详解python中*号的用法
2019/10/21 Python
Python random库使用方法及异常处理方案
2020/03/02 Python
Python退出时强制运行一段代码的实现方法
2020/04/29 Python
关于matplotlib-legend 位置属性 loc 使用说明
2020/05/16 Python
python中取绝对值简单方法总结
2020/07/24 Python
详解CSS的border边框属性及其在CSS3中的新特性
2016/05/10 HTML / CSS
CSS3 滤镜 webkit-filter详细介绍及使用方法
2012/12/27 HTML / CSS
html5使用canvas实现弹幕功能示例
2017/09/11 HTML / CSS
乌克兰的第一家手表店:Deka
2020/03/05 全球购物
户外用品商店创业计划书
2014/01/29 职场文书
美术指导助理求职信
2014/04/20 职场文书
中层领导干部群众路线对照检查材料思想汇报
2014/10/02 职场文书
个人自荐书范文
2015/03/09 职场文书
2015年国庆节活动总结
2015/03/23 职场文书