WEB技術(shù)的桌面化和JavaScript的全椕岣埽化

作者:caoglish鏈接:http://www.zhihu.com/question/36615008/answer/115414003來(lái)源:知乎著作權(quán)歸作者所有,轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán)。
1. WEB技術(shù)的桌面化和JavaScript的全棧化
JavaScript 近些年發(fā)展火熱榆俺,逐漸印證了一個(gè)Atwood法則:**
凡是可以用javascript實(shí)現(xiàn)的,最終都會(huì)用javascript實(shí)現(xiàn)**Nodejs的出現(xiàn)坞淮,奠定了JavaScript走出瀏覽器茴晋,走向了服務(wù)器端
NW的出現(xiàn)和electron正式版發(fā)布,JavaScript走向了桌面
MongoDB的出現(xiàn)回窘,JavaScript走向了數(shù)據(jù)庫(kù)
Tessel的出現(xiàn)诺擅,走向了硬件和物聯(lián)網(wǎng)

如今一個(gè)全棧系統(tǒng),從前端到數(shù)據(jù)庫(kù)毫玖,可以完全使用JavaScript一種語(yǔ)言掀虎。還有很多人正在致力于把JavaScript推向更多的領(lǐng)域中。而Web技術(shù)(html+css+javascript)由于NW和Electron的出現(xiàn)付枫,已經(jīng)可以編寫桌面程序了烹玉。正是由于JS的優(yōu)秀模塊很多,以及HTML+CSS的界面容易編寫和掌控阐滩,糾錯(cuò)工具豐富二打,很多人愿意用Web技術(shù)進(jìn)行開(kāi)發(fā)。現(xiàn)在比較火的桌面工具有VS-Code編輯器和Atom編輯器總結(jié)一下:由于web技術(shù)的便利性掂榔,WEB技術(shù)涉及的領(lǐng)域也就越來(lái)越多继效,再也不是瀏覽器的專利了症杏。2. Web API的全面發(fā)展Web API雖然歷史悠久,但是真正使其推廣流行的應(yīng)該是Twitter瑞信,而后移動(dòng)設(shè)備的普及使其得到更大發(fā)展和普及厉颤。移動(dòng)設(shè)備如果沒(méi)有Web API基本就不能工作了。Web API的普及凡简,也使得網(wǎng)絡(luò)服務(wù)之間相互連通逼友,形成一個(gè)更大的服務(wù)網(wǎng)絡(luò)〕由總之帜乞,如今的Web API已經(jīng)是不可或缺的存在了Web API更多的是一種服務(wù),或是一種數(shù)據(jù)交換模式筐眷。只要語(yǔ)言帶有HTTP的網(wǎng)絡(luò)訪問(wèn)功能黎烈,就都能使用。提供Web API的公司匀谣,發(fā)布Web API后照棋,一般也會(huì)同時(shí)發(fā)布一些常用語(yǔ)言的SDK,方便相應(yīng)語(yǔ)言開(kāi)發(fā)人員快速上手振定;但是如果語(yǔ)言比較小眾必怜,沒(méi)有提供相應(yīng)的SDK也沒(méi)有關(guān)系,編寫一段HTTP的請(qǐng)求后频,也是可以交換數(shù)據(jù)梳庆。從編程的角度來(lái)歸納一下Web API特點(diǎn)就是:容易編寫,就是個(gè)函數(shù)卑惜,無(wú)需界面
語(yǔ)言無(wú)關(guān)性膏执,無(wú)論Web API是個(gè)語(yǔ)言編寫,幾乎任何語(yǔ)言都能調(diào)用
訪問(wèn)性好,無(wú)論在哪,只要網(wǎng)絡(luò)能訪問(wèn)批狐,Web API就可以用桅滋。

3. 語(yǔ)言之間的相互借鑒語(yǔ)言之間的相互借鑒也越來(lái)越明顯了数尿,比如:PHP5.0后支持了類,5.4 后支持了Trait,5.5后支持了生成器(Generator)
Javascript ES6 支持了箭頭匿名函數(shù),生成器(Generator)栏笆,類(不是Prototype的類)
C# 和 Java相互借鑒
Coffee Script借鑒Python和Ruby

與其說(shuō)是相互借鑒,不如說(shuō)隨著語(yǔ)言的發(fā)展臊泰,一些語(yǔ)言概念逐漸成為了標(biāo)配蛉加,如果沒(méi)有,就算是一個(gè)不完整的語(yǔ)言了。比如說(shuō)類针饥,匿名函數(shù)厂抽,常用數(shù)據(jù)結(jié)構(gòu)等都成為了標(biāo)配。4. 語(yǔ)言解析器的工具化語(yǔ)言解析器(Parser)在過(guò)去自是作為編譯器的一部分存在的丁眼。如今筷凤,它已經(jīng)獨(dú)立出來(lái)作為一個(gè)模塊或者工具來(lái)使用了,這個(gè)對(duì)于一個(gè)語(yǔ)言的生態(tài)有著很大的意義户盯,促進(jìn)了語(yǔ)言生態(tài)圈的良好發(fā)展嵌施。獨(dú)立出來(lái)的解析器饲化,可以用來(lái)編寫以下和語(yǔ)言有關(guān)的工具莽鸭,這些工具都是用來(lái)優(yōu)化代碼質(zhì)量的,提高編碼體驗(yàn)的吃靠。語(yǔ)法檢查硫眨,javascript的jshint用的就是javascript的一個(gè)解釋器,被javascript重新解釋一遍巢块,把可能有問(wèn)題的地方標(biāo)記出來(lái)通知程序員礁阁,程序員可修改避免潛在錯(cuò)誤。
代碼最小化族奢,代碼重寫的一種形式姥闭,javascript的最小化項(xiàng)目(比如urglify),是把語(yǔ)法正確讀取后越走,進(jìn)行最小化壓縮棚品。把單詞變量轉(zhuǎn)換成單字母變量。甚至是if else轉(zhuǎn)換成?: 形式廊敌。
語(yǔ)法擾亂器铜跑,就是代碼重寫的一種形式,讓代碼無(wú)法閱讀骡澈,保護(hù)代碼锅纺。
語(yǔ)法整理器,代碼重新的一個(gè)形式肋殴,把無(wú)法閱讀的代碼囤锉,轉(zhuǎn)換成可閱讀的代碼,比如beautifier
語(yǔ)法高亮护锤,一般用于代碼編輯器和代碼顯示組件的官地。
代碼分析器, 把可用的代碼部分進(jìn)行掃描,列出代碼相關(guān)數(shù)據(jù)蔽豺,比如用了多少類区丑,多少對(duì)象,多少變量,多少全局變量等等
代碼清理器沧侥,分析器的加強(qiáng)可霎,清理不用的變量,不用的對(duì)象和宴杀,不用的函數(shù)等癣朗。
自動(dòng)完成,一些IDE可以分析已經(jīng)存在的變化和函數(shù)旺罢,以后在不斷的打字中可以智能的自動(dòng)完成旷余。
代碼追蹤,比如說(shuō)某段代碼被執(zhí)行了幾次扁达,程序報(bào)錯(cuò)時(shí)候正卧,函數(shù)被執(zhí)行的順序,測(cè)試程序時(shí)候的代碼覆蓋率等等
虛擬執(zhí)行跪解,javascript代碼在一個(gè)保護(hù)區(qū)域內(nèi)或環(huán)境執(zhí)行炉旷,代碼可以返回值,但不能影響非虛擬環(huán)境內(nèi)的代碼執(zhí)行叉讥。比如說(shuō)窘行,代碼里面有全局變量,但是虛擬執(zhí)行后這個(gè)全局變量只在虛擬環(huán)境內(nèi)图仓,非虛擬環(huán)境的沒(méi)有這個(gè)全局變量罐盔。

關(guān)于這點(diǎn),我回答過(guò)下面的問(wèn)題救崔。用 JavaScript 寫成的 JavaScript 解釋器惶看,意義是什么? - 知乎用戶的回答5. 數(shù)據(jù)交換語(yǔ)言的發(fā)展數(shù)據(jù)交換語(yǔ)言發(fā)展總體來(lái)說(shuō)就是從XML主流逐漸發(fā)展到JSON主流的過(guò)程. 雖然xml現(xiàn)在應(yīng)用還是非常廣泛帚豪,但是由于其復(fù)雜和標(biāo)簽占用空間大碳竟,逐漸被輕量級(jí)的JSON給代替了。尤其JSON與javascript天然兼容狸臣,無(wú)需解析莹桅,直接使用。所以在很多網(wǎng)絡(luò)技術(shù)中JSON是優(yōu)先使用的烛亦。而如今很多配置文件也是用JSON實(shí)現(xiàn)的诈泼,比如Composer和node的配置文件。JSON的閱讀方式更符合程序員的閱讀習(xí)慣煤禽,格式化后的結(jié)構(gòu)一目了然铐达,容易理解。JSON好處:結(jié)構(gòu)符合程序員閱讀習(xí)慣
文件大小相對(duì)更小
Javascript可以直接使用
在非JavaScript的腳步語(yǔ)言中檬果,轉(zhuǎn)化成數(shù)據(jù)結(jié)構(gòu)更容易
學(xué)習(xí)曲線很短

正是以上這些原因瓮孙,使用JSON作為數(shù)據(jù)交換語(yǔ)言可以說(shuō)在編程界里唐断,是大勢(shì)所趨了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末杭抠,一起剝皮案震驚了整個(gè)濱河市脸甘,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌偏灿,老刑警劉巖丹诀,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異翁垂,居然都是意外死亡铆遭,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門沿猜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)枚荣,“玉大人,你說(shuō)我怎么就攤上這事邢疙」髋” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵疟游,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我痕支,道長(zhǎng)颁虐,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任卧须,我火速辦了婚禮另绩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘花嘶。我一直安慰自己笋籽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布椭员。 她就那樣靜靜地躺著车海,像睡著了一般。 火紅的嫁衣襯著肌膚如雪隘击。 梳的紋絲不亂的頭發(fā)上侍芝,一...
    開(kāi)封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音埋同,去河邊找鬼州叠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛凶赁,可吹牛的內(nèi)容都是我干的咧栗。 我是一名探鬼主播逆甜,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼致板!你這毒婦竟也來(lái)了忆绰?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤可岂,失蹤者是張志新(化名)和其女友劉穎错敢,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體缕粹,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡稚茅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了平斩。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片亚享。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖绘面,靈堂內(nèi)的尸體忽然破棺而出欺税,到底是詐尸還是另有隱情,我是刑警寧澤揭璃,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布晚凿,位于F島的核電站,受9級(jí)特大地震影響瘦馍,放射性物質(zhì)發(fā)生泄漏歼秽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一情组、第九天 我趴在偏房一處隱蔽的房頂上張望燥筷。 院中可真熱鬧,春花似錦院崇、人聲如沸肆氓。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)谢揪。三九已至,卻和暖如春濒持,著一層夾襖步出監(jiān)牢的瞬間键耕,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工柑营, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留屈雄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓官套,卻偏偏與公主長(zhǎng)得像酒奶,于是被迫代替她去往敵國(guó)和親蚁孔。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容