是的, 我就是鼎鼎大名的JavaScript, 典型的高富帥,前端編程之王,數以百萬計的程序員使用我來編程。 若是你沒有用過我就太out了。 javascript
不過當我是一個屌絲時, 真的沒有想到能發展到現在的地位......html
第一章:出世前端
我出生在上古時代的瀏覽器Netscape中, 那個時候的網頁真是乏善可陳, 你可能都想象不到, 主要是些醜陋的靜態文本和簡單的圖片, 和如今美輪美奐的頁面相比,差的實在太遠了, 不信你請看著名的Yahoo 網站:java
GIFnode
那個時候人們還在用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 !
因爲設計時間過短,個人一些細節kao慮得不夠嚴謹,致使後來很長一段時間,Javascript寫出來的程序混亂不堪。若是主人預見到,將來這種語言會成爲互聯網第一大語言,全世界有成千上萬的學習者,他會不會多花一點時間呢?
第二章:成長
Java 是當時的明星語言, nian輕,活力四射 , 他常常嘲笑我: 你小子究竟是個計算機語言嗎?
我說“是啊, 個人語法和你差很少呢”
Java: "你爲何只能在瀏覽器中運行啊? 你能寫個程序單獨運行嗎, 哎對了你能讀取一個文件嗎 ?"
我固然讀取不了文件,我生活在瀏覽器裏, 用我寫的程序只能嵌入在html網頁中, 由瀏覽器中來執行。他們給這個執行模塊起了一個頗有動感的名字: javascript 引擎
我因而反擊Java : “我有個引擎你知道嗎?”可是Java 輕鬆就把我打翻在地: “我還有個虛擬機呢”
nian長的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, 能夠經過菜單查看)
1998nian的時候 ,我和積極進取的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 = <[/span> { "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幾nian之後 , 又一位大牛Ryan Dahl於2009nian真的把我放到了服務器端。這就是node.js
(碼農翻身:《Node.js 我只須要一個店小二》這篇文章介紹了Node.js的原理, 能夠經過公共號的菜單查看)
這下Java無話可說了, 雖然他仍是對我在服務器端執行持懷疑態度, 但愈來愈多使用node.js的網站證實, javascript的確能夠在服務器端立足, 而且有一個巨大的優點:前端和後端都用一樣的開發語言:那就是我 javascript
原來的前端開發如今居然也能夠毫無障礙的寫後端的程序了, 是名副其實的“全棧工程師” !
這就是我,一個屌絲的逆襲, 個人創始人絕對想不到10幾nian後我能成爲這麼一個高富帥, 我估計他夜裏常常會想: "唉,當nian太倉促了, 我要是把javascript 設計的更好一點就行了。"