- 我是一个线程(修订版)
- 我是一个 Java class
- Javascript:一个屌丝的逆袭
- Java : 一个帝国的诞生
- JSP 一个装配工的没落
- TCP/IP 之 大明王朝邮差
- TCP/IP 之大明内阁
- TCP/IP 之蓟辽督师
- CPU 阿甘
- CPU 阿甘之烦恼
- CPU 阿甘:函数调用的秘密
- 我是一个网卡
- 我是一个路由器
- 我是一个进程
- 我是一块硬盘(上)
- 我是一块硬盘(下)
- 我是一个键盘
- 张大胖的 socket
- 张大胖学递归
- 学习面向对象的令狐冲
- 张大胖学数据库
- 数据库村的旺财和小强
- 小李的数据库之旅(上)
- 小李的数据库之旅(下)
- 漫画:什么是机器学习?
- 那些烦人的同步和互斥问题
- IE 为什么把火狐和 Chrome 给打伤了?
- 对浏览器村的第二次采访
- 节约标兵 IE 的自述
- EMail 诞生记
- Email 诞生记(下)
- Http 历险记(上)
- Http 历险记(下)-- Struts 的秘密
- 动物王国的面向对象
- 冯·诺伊曼计算机的诞生
- Http Server : 一个差生的逆袭
- 张大胖的加法器
- 从 1 加到 100:一道简单的数学题挑战下你的大脑
- 编程语言
- Javascript:一个屌丝的逆袭
- 计算机语言之战
- 我和编程语言的爱恨情仇(上)
- 我和编程语言的爱恨情仇(下)
- Android 为什么选择了 Java
- iOS 为什么选择了 Object-C?
- Basic : 一个老兵的自述
- Node.js : 我只需要一个店小二
- 命令式编程 vs 声明式编程
- 编译还是解释?
- 程序人生
- “架构师"小赵
- 师兄说
- 师姐说
- 小王的架构师之路
- 小李的版本管理系统
- 小超穿越记
- 小李的 Build 之路(上)
- 小李的 Build 之路(下)
- 张大胖改 Bug
- 我的编程之路--大学趣事
- 码农小王的一天
- 小李在外企
- 张大胖的需求估算
- 从厨师到码农
- 聊一聊那些神一样的程序员们(上)
- 聊一聊那些神一样的程序员们(中)
- 聊一聊那些神一样的程序员们(下)
- 谁是互联网之父?
- 一个价值百万的创业教训
- 让自己与众不同 - 提升工作的价值
- 看看你的“易燃性”
- 从无聊的工作中寻找价值
- 什么样的学生适合报考计算机?
- 谈谈程序员的职业方向(上)
- 谈谈程序员的职业方向(中)
- 谈谈程序员的职业方向(下)
- 谈谈培训班的作用
- 码农需要知道的“潜规则”
- 学习编程的加速度
- 码农在工作中的必备能力
- 码农和英语
- 老司机经验
- 假如时光能够倒流, 我会这么学习 Java
- 假如我是计算机系老师
- 学会编程, 而不是学会 Java
- 从增删改查中突围
- 抽象:程序员必备的能力
- 懒就一个字
- 编程的自学方法
- 小王买房记
- 从一道面试题谈谈一线码农应该具备的基本素质
- 想写框架的看过来
- 苹果手机变砖头以后
- 如何快速的学习一门技术?
- 唯一不变的是变化: 谈谈微信应用号
- 什么是企业应用?
- 勿以浮沙筑高台
- 为什么敏捷开发难于成功?
- localhost vs 127.0.0.1
- GitHub/Stackoverflow 找工作时有什么用?
- 动词 or 名词 :这是一个问题
- 如何选择入行语言
- 有时候,沉默是金
- 零 Bug 的代码是怎么炼成的?
- 浮点数为什么不精确?
- 文章错误大全
- Open Source--不要为了开源而开源
- 一不留神,代码就腐化了
- 先做个“键盘侠”, 再来写程序
- 不加断点调试的程序员是好程序员
- 码农必备技能:烂代码的处理之道(上)
- 码农必备技能:烂代码的处理之道(下)
- 学习数据结构有用吗?
- 从现在开始,丰富你的简历
- 那些永不过时的书,你看过几本吗?
- 学好编程必备的一个品质你知道吗?
- 你最爱的 Java
- 搞懂了这几点,你就学会了 Web 编程
- Spring 的本质系列(1) -- 依赖注入
- Spring 本质系列(2)-AOP
- 三层架构和 MVC 那点事儿
- Java 帝国之拨云见日识回调
- 小张的 Duck Typing
- JDBC 的诞生
- JDBC 后传
- 一个不安分的 JDBC 驱动
- Java 帝国之 Java bean (上)
- Java 帝国之 Java bean(下)
- Java 帝国之函数式编程
- Java 帝国之函数式编程(下)
- 关于 Java 初学者需要知道的 10 件事
- JUnit 你不知道的那些事儿
- 圣诞礼物:Java EE 的历史
- Java EE 读书指南
- 给小白的 Java EE 指南
- 给小白的 Java EE 指南(2)
- 给小白的 Java EE 生存指南(3) : XML
- 给小白的 Java EE 生存指南(4) : 一只叫 Tom 的猫
- 给小白的 Java EE 指南(5) : AJAX
- 给小白的 Java EE 生存指南(6) :Java 反射
- 闲聊
- "饿了么"初体验
- 来自大脑的控诉
- 一个高中生是怎么玩自媒体的?
- 尝试 分答
- 到底应不应该上培训班?
- 自学编程中遇到问题怎么办?
- 据说 99%的初级程序员看完后都不迷茫了
- 一行代码引发的“血案”
- 对一个死锁问题的思考
- 通过外包进入名企
- 请开往十年前的今天
- 为什么自学中最好有个师傅指导一下?
- 这个网站值得你花时间投入
- 为什么你无法坚持自学编程?
Javascript:一个屌丝的逆袭
是的, 我就是鼎鼎大名的 Javascript, 典型的高富帅,前端编程之王,数以百万计的程序员使用我来编程。 如果你没有用过我就太 out 了。 不过当我是一个屌丝时, 真的没有想到能发展到如今的地位...... 第一章:出世 我出生在上古时代的浏览器 Netscape 中, 那个时候的网页真是乏善可陈, 你可能都想象不到, 主要是些丑陋的静态文本和简单的图片, 和现在美轮美奂的页面相比,差的实在太远了, 不信你请看著名的 Yahoo 网站: 那个时候人们还在用 Modem(调制解调器)通过电话线拨号上网, 每次拨号都有种吱吱啦啦声音, 就像一个铁片努力的刮一个锅底,让无数人抓狂不已。
这还不算什么, 网速只有 28.8kbit /s , 下载一个网页都得耐心的等待半天。
我的主人 Brendan Eich 有一回用公司的 Netscape 上网购物的时候, 需要注册用户, 填了一个表单, 点击了提交按钮, 等待了 38 秒, 然后服务器告诉他:“对不起, 您忘了选择性别了”
他几乎要崩溃:“靠,怎么能够这样! 这么简单的问题浏览器怎么不告诉我, 还得让我把数据提交到几千公里外的服务器网站, 然后在那里检查才能发现问题吗!”
对浏览器进行改革势在必行!
Brendan Eich 于是去找老板: “我实在是受不了了, 我需要一种脚本语言运行在浏览器中, 帮助我完成这些本来就应该在浏览器中完成的任务“
老板: “我们 Netscape 公司也早有此意, 要不你来设计一个吧”
Brendan Eich: “好啊, 你听说过 LISP(确切的说是 Scheme)吗, 当今最牛的编程语言,我们公司何不把 Scheme 运行在浏览器中呢? “
老板: "LISP 有谁会用啊? ”
Brendan Eich: "......"
老板: "我们正在和 Sun 公司合作, 你听说过他们刚发明的 Java 吗, 那个运行在浏览器中的 Applet 简直是酷毙了,Java 肯定是未来的网络语言。 所以你要搞个新语言出来,要和 java 足够相似, 但是要比 java 简单的多的多, 这样那些网页开发人员就可以用了。 ”
我的主人 Brendan Eich 很郁闷, 但是也没有办法, 他对 java 毫无兴趣, 为了应付公司的任务, 他只花了 10 天就把我设计了出来, 对了, 我本来叫 LiveScript, 但是为了向“万恶”的 Java 示好, 我竟然被改成了 Javascript !
由于设计时间太短,我的一些细节考虑得不够严谨,导致后来很长一段时间,Javascript 写出来的程序混乱不堪。如果主人预见到,未来这种语言会成为互联网第一大语言,全世界有成千上万的学习者,他会不会多花一点时间呢? 第二章:成长 Java 是当时的明星语言, 年轻,活力四射 , 他经常嘲笑我: 你小子到底是个计算机语言吗?
我说“是啊, 我的语法和你差不多呢”
Java: "你为什么只能在浏览器中运行啊? 你能写个程序单独运行吗,哎对了你能读取一个文件吗 ?"
我当然读取不了文件,我生活在浏览器里, 用我写的程序只能嵌入在 html 网页中, 由浏览器中来执行。他们给这个执行模块起了一个很有动感的名字: javascript 引擎
我于是反击 Java : “我有个引擎你知道吗?” 但是 Java 轻松就把我打翻在地: “我还有个虚拟机呢”
年长的 C 也问我:你怎么不编译运行啊, 你看我编译以后,运行的多快。 我说: 省省吧, 要是每个页面打开后都先编译 javascript ,那多慢啊。
不仅仅是 Java 和 C , 包括 VB, Delphi 等当时流行的语言都瞧不起我,背地里叫我屌丝。
也是, 我没法独立运行, 也不能像 VB,Delphi 他们画出漂亮的界面, 我能做的就是操作 HTML 的 DOM 和浏览器。 你可能不知道 DOM 是什么东西, 这么说吧, 浏览器从服务器取到 HTML 网页以后, 会展示成页面让你看, 但是他的内部其实会把 HTML 组织成一个树给我, 这个树可以称为 DOM。 例如这个页面: <html>
<head>
<title>Sample Page</title>
</head>
<body>
<p>hello world!</p>
</body>
</html>
DOM 树会长成这样: (:该例子来自 w3school)
有了这棵树, 我就能大展身手,我可以定位到 DOM 树中任意一个节点, 然后对这个节点进行操作, 例如隐藏节点、显示节点、改变颜色、获得文本的值, 改变文本的值 ,添加一个响应点击事件的函数 等等等等, 几乎可以为所欲为了。
更重要的是, 这些操作可以立刻展示出效果来, 你完全不用刷新网页。
注意这些操作完全是内部进行的, html 源码并不会改变, 所以有时候你打开 html 源码,会发现这些源码和你在浏览器中看的效果并不一致, 那就是我在背后改变了这个 DOM 树了。
我的主人 Brendan Eich 最初遇到的问题简直就是小菜一碟了, 做个简单的表单验证,太简单了。
不只是操作 DOM, 我还能控制浏览器, 比如打开窗口, 在一个窗口内前进,后退, 获得浏览器的名称, 版本 等等。 你可能要问了, 为啥还要获得浏览器的名称和版本呢?
说起来惭愧, 在 Netscape 和 IE 进行浏览器之战的期间, 他们都争相在自己的浏览器中支持 Javascript, 并且为了锁定程序员, 还开发了很多自己浏览器的独特功能, 有些功能只能在 IE 用, 有些只能在 Netscape 用, 所以必须的判断是什么浏览器, 这样才能特殊处理。
不管怎么说, 我的这些本事让浏览器中的网页变的更加动态了, 更加有趣好玩了。
但仅限于此, 我被困在浏览器和网页上, 别的什么也干不了。
用 Java 的话来说: 这些都是雕虫小技,奇技淫巧, 只是一个打着我的羊头卖狗肉的屌丝而已。 第三章: 第一桶金 互联网的发展超出了所有人的预料, 我被应用在几乎每一个网站上, 但我一直很苦闷: 我作为一门语言,在浏览器中运行, 没法像 java 那样访问网络, 也就没有办法调用服务器端的接口来获取数据。
用户只能通过 GET 或者 POST 向服务器发送请求,这时候服务器返回的数据是 整个页面 , 而不是页面中的一个片段, 也就是说整个页面都得刷新一遍, 哪怕是页面中只有一个文字的改变。
(注: 《IE 为什么把 Chrome 和火狐打伤了》这篇文章介绍了 HTTP 的 GET 和 POST, 可以通过菜单查看)
1998 年的时候 ,我和积极进取的 IE5 做了一次会谈, 双方就共同关心的话题深入的交换了意见, 最后一致同意, 在 IE5 中引入一个新的功能:XMLHttpRequest , 这个新功能将允许我直接向服务器发出接口调用!
每当发起调用时, IE5 通常会这么说: "小 JS 啊, 来, 你拿这个用户名和密码访问一下服务器端处理登陆的接口 , 这个过程很费时间,我就不等你了, 先干别的事儿去了, 你得到服务器端的返回数据以后, 一定要记着调用下我给你的这个函数啊。 "
我知道这其实叫做异步调用, 于是就乖乖的通过 XMLHttpRequest 访问那个登录的 url, 耐心的等待服务器干完活,把数据传输回来, 然后我就去调用那个函数, 基本是就是把 DOM 树的某个节点更新一下, 例如让那个包含用户名和密码登陆框消失, 再加一个提示消息:登录成功 , 这事儿我很擅长。
如果服务器处理和网络速度都足够快的话, 用户就会发现: 咦, 我没有刷新整个页面, 竟然已经登录了啊。
我和 IE 都没有料到,这个功能带来了一场革命: 这种方式可以使得网页局部刷新, 让用户浏览网页的体验极佳, 尤其是 Google 地图, Gmail 等应用让互联网应用火了起来。
其他浏览器也迅速跟进,实现了类似功能, 各种各样交互性极佳的网站如雨后春笋般出现。
VB 和 Delphi 慢慢的不再嘲笑我了, 因为他们绝望的发现, 他们擅长的桌面应用慢慢的都被搬到了互联网上, 没人再喜欢他们了。
我, Javascript, 挖到了第一桶金,开始走向人生巅峰。 第四章: 发明 JSON 后来有个好事之徒把上面的那种处理方式称为 AJAX 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML), 其实异步挺好, 但是 XML 就很不爽了。
比如说服务器返回了下面这段 xml : <book> <isbn>978-7-229-03093-3</isbn> <name>三体</name> <author>刘慈欣</author> <introduction>中国最牛的科幻书</introduction> <price>38.00</price> </book>
真正的数据很少, 标签(像<name>这样的)反而占了大头, 把数据都给淹没了。
我对 XML 说: “你是不是太臃肿了, 传输起来多费劲啊。”
XML 说:“切,你这就不懂了,这样很优雅啊,格式化良好, 人可以读, 程序也可以读啊。”
"优雅个啥啊, 无用的数据这么多, 再说我还得用 XML 解析器来解析你, 费了劲了!"
"你真是屌丝啊,连个解析都搞不定, 你看人家 Java, 用我用的多 Happy , Spring, Struts, Hibernate, 几乎所有配置文件都是我。"
Java 也在一旁帮腔: 是啊, 我解析的时候还用 DTD 做校验呢, 看看 XML 数据合法不合法。
我无语。
记得 CPU 阿甘说过:既然改变不了别人, 那就改变一下自己吧。
我看了看我的语法, 里边有个叫对象的东西,它有一个花括号, 在括号内部,对象的属性以名称和值对的形式 (name : value) 来定义, 属性由逗号分隔, 像这样: var book = { "isbn": "978-7-229-03093-3", "name": "三体", "author": "刘慈欣", "introduction": "中国最牛的科幻书", "price": "38.00" }
这种结构完全可以表达上面的 xml 内容啊! 我的语法还支持数组,这样表达多个对象也不在话下啊: var books = [ { "isbn": "978-7-229-03093-3", "name": "三体", "author": "刘慈欣", "introduction": "中国最牛的科幻书", "price": "38.00" }, { "isbn": "978-7-229-03094-1", "name": "我是一个线程", "author": "刘欣", "introduction": "一个线程的自述", "price": "0.0" } ] 数组和对象都支持嵌套, 任何复杂的结构都可以保存!
更重要的是, 如果采用这种结构, 我根本不用什么 XML 解析器去解析了,它就是我语言的一部分。 直接拿来用即可。
books[0].name -->返回“三体” books[1].introduction --> 返回“一个线程的自述”
生活不要太爽啊 :-)
我把这种简洁的格式叫做 JSON, 并且和服务器约定, 我们以后都用 JSON 来传输数据。
至于 XML, 还是让 Java 这样的老学究去用吧。 第五章:人生巅峰 HTML 负责结构, CSS 负责展示, 而我(加上 AJAX, JSON) 负责逻辑。 于是前端编程三剑客形成了。
ExtJS, prototype, JQuery 这些框架把前端编程推向另外一个高峰。
甚至出现了 AngularJS 这样的奇葩,实现了 SPA(单一页面应用程序), 实在是难于想象。
我给 Java 说: Java 兄, 现在我完全可以在浏览器端实现 MVC 了, 你只需要在服务器端通过接口给我提供数据就行了。
但是 Java 还是给我泼冷水: 别得意忘形了, 服务器端才是核心, 要不你到服务器端试试?
我很诧异:“服务器端? 我还真没有想过, 住在 64G 内存, 32 核的 CPU 这种拥有几乎无限资源的机器上是什么感觉? ”
"感觉没你想象的好 " Java 没声好气的说 “多线程编程, 很多东西都要加锁, 一不留神就掉到坑里。 我这里基本一个请求就是一线程来处理, 遇到数据库操作, 虽然慢的要死,线程也得等待。 ”
"那不能改成异步操作吗?像我的 AJAX 一样, 数据来了再通知我 " 我问 Java。
"不行, 一开始就是这样, 现在改不了"
把 Javascript 放到服务器端执行怎么样? 这个想法够疯狂的。
首先得把浏览器端的运行环境, 就是 javascript 引擎移到服务器端, 这个引擎执行 javasript 得足够快,要不 Java 还不得笑死我。 原来的引擎一直不合格, 知道 Chrome V8 的出现, 才解决问题。
其次得绕开 java 服务器的问题: 线程遇到 IO/数据库/网络 这样的耗时操作, 不能等待, 得搞成异步处理。
但的确有人这么做了, 在我的创始人 Brendan Eich 发明了我 10 几年以后 , 又一位大牛 Ryan Dahl 于 2009 年真的把我放到了服务器端。这就是 node.js
(:《Node.js 我只需要一个店小二》这篇文章介绍了 Node.js 的原理, 可以通过公共号的菜单查看)
这下 Java 无话可说了, 虽然他还是对我在服务器端执行持怀疑态度, 但越来越多使用 node.js 的网站证明, javascript 的确可以在服务器端立足, 并且有一个巨大的优势:前端和后端都用同样的开发语言:那就是我 javascript
原来的前端开发现在竟然也可以毫无障碍的写后端的程序了, 是名副其实的“全栈工程师” !
这就是我,一个屌丝的逆袭, 我的创始人绝对想不到 10 几年后我能成为这么一个高富帅, 我估计他夜里经常会想: "唉,当年太仓促了, 我要是把 javascript 设计的更好一点就好了。"
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论