你得学JavaScript

标签: javascript | 发表时间:2011-09-01 11:16 | 作者:程序员 蒋冰
出处:http://www.jobbole.com/blog.php
  注:本文由 敏捷翻译 - 蒋少雄 翻译自 Kenny Meyers 的博文。如需转载,请参照文后申明。

  如果三年前你问我应该学什么语言,我会告诉你是Ruby。如果六年前呢,我会说是PHP。

  如果你现在想学一门语言的话,你应该学习JavaScript.

  为什么这样说呢?

  我认为,每一位Web开发人员都应该学习JavaScript。目前推出的许多新技术都支持这个观点。而这之后的唯一原因就是,它太普及了。你可以使用JavaScript为各种人做出令人惊叹的作品。你可以在任何一台机器上立刻开始工作。

  不是所有公司都用Ruby,也不是所有公司都用.NET。而我相信,绝大多数时候,这些公司都需要深入理解JavaScript的人。微软、Facebook、苹果还有谷歌他们都用javaScript 做出了非常优秀的产品。

  作为一个程序员,学习JavaScript或许是你能做到的,最有挑战性,同时也是最有益处的事情了。这是一种变化繁多的语言,在程序中代码量比你想象的更要庞大。它含有大量的新知识,一些好用的新API,还有它在持续发展。

  当人们谈到HTML5的时候,议论的内容大多都是JavaScript。

  但是从何开始呢?

  学习JavaScript的起点就是处理网页,使用DOM进行操作。很多JS程序员在这上面有有问题,因为当Ajax出现和JS改革之前,JavaScript作为一个DOM处理器一直被低估了。你应该清楚,它强过网站上的显示/隐藏机制。

  操作处理DOM是容易并且立即见效的。我找到过最好的DOM处理方面书籍是《JavaScript DOM 编程艺术》。好消息是它终于有了一个非常必需的更新版。阅读Jeremy Keith的书,对于学习JavaScript的一些基础知识是非常好的入门选择。

  这仅仅是开始。如果你渴望了解更多知识,就去看看这个在Stack Overflow上的问题吧。这里有很多很棒的推荐读物,我也读过其中很多。《JavaScript权威指南》这本书可算是JavaScript的圣经,强烈推荐。

  (编注:Stack Overflow 上推荐不少书,其中有中文版的是:《精通JavaScript》、《JavaScript语言精粹》、《高性能JavaScript》、《JavaScript高级程序设计》和《JavaScript入门经典》,当前也包括作者推荐的那本。)

  我还推荐Angus Croll的JavaScript博客,这是用来理解JavaScript核心最好的博客,没有之一。这个博客非常的优秀和透彻,几乎让那些知识主动跳进你小小的脑袋中。Douglas Crick的博客也很好,但是Angus讲述的更细致。

  框架是个好东西,因为它很有用。当你在学习使用框架时,如果有人嘲笑你,别理他们。你的方向是正确的。我认为jQuery比任何书或参考文档都使更多人领悟到在JavaScript中上下文的重要。厚着脸皮,向核心深入吧。

  去安装火狐和Firebug。 我依旧认为firebug是个很好的装备。Webkit也在迎头赶上。可以在firebug主站上通过介绍影片来了解它是如何工作的。就像我朋友兼同事的 Leevi Graham说的:“Firebug…仍与火狐有关。”(资源)。他们刚刚推出了新版本。

  Mozilla无愧于他们的声誉,依旧拥有着最好的JavaScript在线文档。这应该作为你的参考。

  学习JavaScript吧,它比你所能想到的任何语言更重要。

  -------------------------------------------------------------------
  你可能对以下文章也感兴趣

  程序员应知道的12件事
  5个基于Web的建模工具
  人工智能碰上人工智能:两个机器人的爆笑对话
  28个实用的源码-文档比较合并工具
  惹恼程序员的10种事
  
  -------------------------------------------------------------------
  译文出处:伯乐在线 - 职场博客 - 程序员
  译文链接:http://www.jobbole.com/entry.php/1361

  原文:Kenny Meyers   编译:敏捷翻译 - 蒋少雄

  如需转载,但请注明原文/译文出处、译文超链接和译者等信息,否则视为侵权,谢谢合作!

  

相关 [javascript] 推荐:

Javascript诞生记

- Milido - 阮一峰的网络日志
二周前,我谈了一点Javascript的历史. 今天把这部分补全,从历史的角度,说明Javascript到底是如何设计出来的. 只有了解这段历史,才能明白Javascript为什么是现在的样子. 我依据的资料,主要是Brendan Eich的自述. "1994年,网景公司(Netscape)发布了Navigator浏览器0.9版.

JavaScript,你懂的

- dylan - keakon的涂鸦馆
经常有人问我,JavaScript应该怎么学. 先学基本语法,如果曾学过C等语言,应该1小时内就能掌握了. 再去使用内置的函数、方法和DOM API,熟悉它能干什么;而在学习DOM API的过程中,你还不得不与HTML和CSS打交道. 然后弄懂匿名函数和闭包,学会至少一个常用的JavaScript库(例如jQuery).

Javascript 里跑Linux

- rockmaple - Shellex's Blog
牛逼到暴的大拿 Fabrice Bellard,用Javascript实现了一个x86 PC 模拟器,然后成功在这个模拟器里面跑Linux(请用Firefox 4 / Google Chrome 11打开,Chome 12有BUG). 关于这个东西… 伊说 “I did it for fun“,大大啊大大啊….

高效 JavaScript

- xtps - ITeye论坛最新讨论
传统上,网页中不会有大量的脚本,至少脚本很少会影响网页的性能. 但随着网页越来越像 Web 应用程序,脚本的效率对网页性能影响越来越大. 而且使用 Web 技术开发的应用程序现在越来越多,因此提高脚本的性能变得很重要. 对于桌面应用程序,通常使用编译器将源代码转换为二进制程序. 编译器可以花费大量时间优化最终二进制程序的效率.

你得学JavaScript

- 蒋冰 - 伯乐在线 -博客
  注:本文由 敏捷翻译 - 蒋少雄 翻译自 Kenny Meyers 的博文.   如果三年前你问我应该学什么语言,我会告诉你是Ruby.   如果你现在想学一门语言的话,你应该学习JavaScript..   我认为,每一位Web开发人员都应该学习JavaScript. 目前推出的许多新技术都支持这个观点.

javascript 贪食蛇

- Xin - 博客园-首页原创精华区
我的程序用javascript与Html中的table结合,实现的简单的贪食蛇游戏,游戏的主要特点,可调整蛇移动速度,可调整蛇移动范围,碰壁、咬到身体则“Game Over. 游戏并不完善,只是实现了主要的功用,有设计不合理的地方,欢迎您感大家提意见.        实现方法:由javascript语言中的setInterval方法驱动整个游戏程序,设置“nowDirection”即蛇的当前移动方向为全局变量,由setInterval方法定时获取蛇的移动方向,由document.onkeydown()捕捉当前按键(上、下、左、右)以修改nowDirection,这样就可以用方向按键控制蛇周期时间的定向移动.

你不懂Javascript

- 英建 - 黑客志
过去几年我注意到技术圈一个很奇怪的现象,有太多程序员将那些他们只是有过非常浅显的了解,但其实根本就不懂的技术写到他们的简历中,这个现象几乎每种语言都有,但这其中最严重的就要数Javascript了. 出现这种状况的一个很大的原因就是现如今几乎每个开发者的工作都或多或少要依赖于Javascript,但大多数人并不真的理解这门语言,他们常用的学习方式是复制粘贴,使用这种方式,你永远不会真正学会这门语言,而只能得到一个你已经懂了的假象.

Javascript 中的 var

- - 酷壳 - CoolShell.cn
MelonCard发布了一篇文章——” how one missing var ruined our launch“(”少写了一个var毁了我的网站”),这篇文章是说MelonCard用Node.js做后台,因为出了一个小高峰——有50-100人注册,结果整个网站都不响应了,而且还出现了很多奇怪的问题.

JavaScript 基础

- - CSDN博客推荐文章
JavaScript可以出现在HTML的任意地方,甚至在之前插入也不成问题,使用标签. 不过要在框架网页中插入的话,就一定要在之前插入,否则不会运行. JavaScript对数据类型要求不严格,一般来说,声明变量的时候不需要声明类型,而且就算声明了类型,在使用过程中也可以给变量赋予其他类型的值,声明变量使用var关键字.

javaScript DOM使用

- - CSDN博客互联网推荐文章
通过 HTML DOM,可访问 JavaScript HTML 文档的所有元素. 1 修改HTML元素内容. document.write(Date()); //在输入流中直接写 document.getElementById(id).innerHTML=new HTML. //改变已经有的元素内容 document.getElementById("image").src="landscape.jpg";.