精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

熱點推薦:2015前端生態發展回顧

開發 前端
引用蘇寧前端架構師的一個總結作為開篇,編程技術及生態發展的三個階段: 最初的時候人們忙著補全各種API,代表著他們擁有的東西還很匱乏,需要在語言跟基礎設施上繼續完善 然后就開始各種模式,標志他們做的東西逐漸變大變復雜,需要更好的組織了 然后就是各類分層MVC,MVP,MVVM之類,可視化開發,自動化測試,團隊協同系統等等,說明重視生產效率了,也就是所謂工程化

處在2015年這個時間段來看,前端生態已經進入了第三階段。看上去好像已經走的挺遠了,實則不然。如果再用人類歷史上的三次工業革命來類比,前端 發展其實不過剛剛邁入了蒸汽機時代,開始逐步用工具來替代過往相當一部分的人肉作業,但是離電氣時代的自動化流水線作業還有很長一段路要走。回顧一下 2015年前端的生態發展,我大致整理了幾個我覺得比較有歷史意義的事件。

[[160818]]

按時間順序:

  1. 年初 React Native 的發布,引領 React 正式走上歷史舞臺。

  2. 3月 angular2.0 第一個預覽版發布

  3. 5月 http/2.0 標準正式發布,同月 iojs 與 nodejs合并。

  4. 6月 ES6 和 WebAssembly 落地

  5. 7月 迄今為止React生態圈影響最大的Flux實現redux發布1.0版本

  6. 8月 Facebook公開了在React上應用GraphQL的relay框架的技術預覽版

  7. 9月 React Native for Andriod 發布

  8. 11月伊始,es標準委員會宣布將歷時3年研究的Object.observe從草案中移除,盡管它原本已經是stage2,幾乎已經是ES7的 事實標準。雙十一剛一結束,阿里手淘團隊發布了名為 無線電商動態化解決方案 的 Weex,也有人給了它一個更具象的名字,vue native。

  9. 12月,趕在2015的尾巴,aurelia和angular2先后發布beta版。

css方面,postcss & cssnext先后高調走到臺前。

觀念的變化

由于近幾年前端的野蠻生長以及前端應用的多元化和復雜化,整個技術形態已經跟幾年前純做頁面的時代完全迥異了。主要觀念的變化總結來看在于一點,現在的前端開發面向的是web app而不是web page。 今天的前端開發模式跟傳統的GUI軟件(如C++、.NET開發的windows客戶端)已經很接近了,而且由于現在前端領域為了解決日益復雜的web業 務需求及體量,越來越多的借鑒了傳統客戶端的開發經驗,導致兩者變得越來越趨同。再加上前端一些獨特的特性(免安裝、增量安裝等),工程上的復雜度有過之 而無不及。前端如今已經脫離了茹毛飲血、刀耕火種的原始社會,開始步入了工業時代。

框架 & 類庫的變化

今年最火的框架/類庫毫無疑問當屬React了。React從2014年年中開始廣泛受到開發者關注,但是真正開始在社區獨領風騷還得歸功于 2015年初React Native的發布。React Native的發布使得js統一三端(前端、后端、移動端)開發成為可能(現在這個時間點看可能還是過于理想,但是整體方向還是對的),這一針強心劑吸引 了大量開發者的眼球。筆者對此最大的感受就是,我在社區發表一篇react的入門教程級別的軟文便可獲得廣泛關注及轉發,相應的寫angular源碼剖析 的準干貨大部分情況則是門可羅雀。

我們挑幾個主流的框架來講講這一層的變化。

React & Redux

React基本簡介可以參考這篇文章React簡介,這里不再贅述。這里挑幾個核心特征簡單來講:

  1. virtual dom
    這個可以說是F家工程師超強工程能力的最佳體現了(Relay也算一個),從本質來看它是通過用js object來模擬了一個dom tree,然后將這層virtual dom插在react組件跟真實dom之間,配合強勁的dom diff算法實現它一直標榜的高性能。

  2. jsx
    同樣為了配合react中的組件化開發模式,F家發明了一套新的語法jsx。乍看之下它像是html in js,這也是初接觸的開發者最難以接受的,典型的違背前端推崇多年的表現與業務分離的原則啊。其實這里要換個角度來看jsx,它并不是html in js,準確來說它是一個用來構建react組件樹的AST。這樣來想你就能理解react中這一看似怪異的設計了。

  3. immutable object
    不可變對象是函數式編程中的重要概念,react的介入使得這一理念在前端社區中流行起來。從目前各種類庫的實現來看,不可變對象在大型應用中擁有傳統可 變對象不具備的優勢。尤其在這個內存不值錢的年代。從目前immutable object的良好走勢來看,將來有可能被es納入規范之中。目前可以通過facebook的immutable.js來實現。

Redux則是目前react配套的Flux模式的各種實現(其實現在兩者的關系越來越模糊了)中最火的一個,在此基礎上它引入了函數式編程、單一 數據源、不可變數據、中間件等概念。一定程度來講,redux是今年react生態甚至整個前端生態中影響最大的一個框架,它給整個前端技術棧引入了很多 新成員,盡管這些概念可能在其他領域已經有了廣泛的應用。雖然它們是否會在大規模的應用實踐中被廣大開發者認可還需要再檢驗,但至少給我們帶來了一些新的 思路。其中的單一數據源、不可變數據、中間件等思路目前來看還是非常有價值的,尤其是單一數據源跟不可變數據,很有可能在將來成為大型應用架構中的標配 (目前來看至少在應用中構建Store層在當前的前端架構中是勢在必行的)。單一數據源就好比在前端構建了一個集中式數據庫,所有的數據存取操作對象都是 它,不單如此它里面還實現了觸發器,當有insert/update操作時它會對相應組件作rerender動作,這個在各組件之間有數據同步需求的場景 下就非常有用了。

至于我對函數式編程的看法,后面單獨闡述。

在我看來,react的優勢并不在組件化,組件化的實現方案多種多樣。react的優勢在于virtual dom及一個幾乎構成閉環的強大生態,這歸功于F家工程師強大的工程能力跟架構能力。virtual dom將應用表現層從瀏覽器這個基于dom的上下文中抽離出來,通過原生js對象模型的方式使得react具備在任何環境支撐上層表現的能力。上層的渲染 引擎可以是canvas、native、服務端甚至是桌面端,只要相應的端提供基于react組件的渲染能力,即可達到一套代碼、或者只要很少的改動就能 移植到任一終端環境的效果,這個就非常夸張了。react從0.14版本之后便將react-dom抽出來變成一個獨立的庫,可見react的野心并不局 限于瀏覽器,相反從這點來看,react反而是受到了dom的掣肘。

Angular2 & Vue.js

ng2跟ng1相比是一個完全革命性版本而不是升級版,它是一個為了迎合未來的標準及理念來設計的全新框架,而這些新的理念又無法通過改進 ng1.x的方式來實施,所以angular團隊做了這么一個看似激進的決策,可以理解成重構已經無法滿足需求只能重寫了。ng2也采用純組件化的開發思 路,任何單元對于它來說都是組件。同時,ng2里面也引入了一些全新的概念(對于前端而言)來提升框架的性能及設計,例如基于worker的數據檢測機制 能大幅度提升渲染性能(對應實現是zone.js),基于響應式編程的新的編程模型能更大的改善編碼體驗(對應實現RxJS)。趕在2015年的尾 巴,ng2正式發布beta版,對于angular的這次自我革命是否能成功,還有待后續檢驗。另外原angular團隊中出來的一個成員開發了一個類 ng2的框架aurelia,有相當的開發者認為它更配稱為ng2,值得關注。

由于阿里在背后的技術實踐及支持,Vue.js今年也開始得到越來越多的關注。vue相對于angular1.x的優勢在于輕量、易用、更優異的性能及面向組件化的設計,目前發展態勢也非常好,是移動端開發的一個重要技術選型之一。

標準 & 語言的變化

現在回顧起來,2015年真的是很有意義的一年:這一年是Web的25歲生日,也是js的20歲生日。同時又是ES6標準落地的一年。ES6是迄今 為止ECMAScript標準最大的變革(如果不算上胎死腹中的ES4的話),帶來了一系列令開發者興奮的新特性。從目前es的進化速度來看,es后面應 該會變成一個個的feature發布而不是像以前那樣大版本號的方式,所以現在官方也在推薦 ES+年份 這種叫法而不是 ES +版本。

ES2015(ES6) & ES2016(ES7) & TypeScript

6月中ES2015規范正式發布,從ES2015帶來的這些革命性的新語法來看,JS從此具備了用于開發大型應用的語言的基本要素:原生的 mudule支持、原生的class關鍵字、更簡潔的api及語法糖,更穩定的數據類型。而這些new features中,有幾個我認為是會影響整個前端發展進程的:

  1. Module & Module Loader

    ES2015中加入的原生模塊機制支持可謂是意義最重大的feature了,且不說目前市面上五花八門的module/loader庫,各種不同實現機制 互不兼容也就罷了(其實這也是非常大的問題),關鍵是那些模塊定義/裝載 語法都丑到爆炸,但是這也是無奈之舉,在沒有語言級別的支持下,js只能做到這一步,正所謂巧婦難為無米之炊。ES2016中的Module機制借鑒自 CommonJS,同時又提供了更優雅的關鍵字及語法(當然也存在一些問題)。遺憾的是同樣有重大價值的Module Loader在2014年底從ES2015草案中移除了,我猜測可能是對于瀏覽器而言Module Loader的支持遭遇了一些技術上的難點,從而暫時性的舍棄了這一feature。但是一個原生支持的模塊加載器是非常有意義的,相信它不久后還是會回 歸到ES規范中(目前由WHATWG組織在單獨維護)。

  2. Class

    準確來說class關鍵字只是一個js里構造函數的語法糖而已,跟直接function寫法無本質區別。只不過有了Class的原生支持后,js的面向對象機制有了更多的可能性,比如衍生的extends關鍵字(雖然也只是語法糖)。

  3. Promise & Reflect API

    Promise的誕生其實已經有幾十年了,它被納入ES規范最大意義在于,它將市面上各種異步實現庫的最佳實踐都標準化了。至于Reflect API,它讓js歷史上第一次具備了元編程能力,這一特性足以讓開發者們腦洞大開。

關于ES2016的最重磅的消息莫過于11月初es標準委員會宣布將Object.observe從ES2016草案中移除了,盡管它已經是 stage2幾乎已經是事實標準。官方給出的解釋是,這3年的時間前端世界變化實在太大,社區已經有了一些更優秀簡潔的實現了(polymer的 observe-js),而且React帶來的immutable object在社區的流行使得基于可變數據的Object.observe的處境變的尷尬,O.o再繼續下去的意義不大了。

除此之外,ES2016的相關草案也已經確定了一大部分其他new features。這里提兩個我比較感興趣的new feature:

  1. async/await

    寫過C#的同學應該對這兩個關鍵字很熟悉了,async/await是為了更優雅的異步編程做的一個關鍵字級別的封裝,術語叫協程。ES2016中 async/await 實際是對Promise的上層封裝,幾乎同步的寫法寫異步比Promise更優雅更簡單,非常值得期待。

  2. decorator

    字面意思是裝飾器,其實等同于Java里面的注解。注解機制對于大型應用的開發的作用想必不用我過多贅述了。用過的同學都說好。

目前ES2015/ES2016都有了比較優秀的轉譯器支持(沒錯我說的是babel),但是也不是all features supported,嘗新的過程中需要注意。

至于Typescript,你可以將它理解成加入了靜態類型的js的超集。不過我對于這種轉譯型語言一直不感冒(包括快死掉的CoffeeScript),有興趣同學自己去了解下吧。。

WebAssembly

WebAssembly選擇了跟ES2015在同一天發布,其項目領頭人是大名鼎鼎的js之父Brendan Eich。WebAssembly旨在解決js作為解釋性語言的先天性能缺陷,試圖通過在瀏覽器底層加入編譯機制從而提高js性能。這個事情跟當時V8做 的類似(有興趣的同學可以去了解下JIT),V8也因此一躍成為世界上跑的最快的js引擎。但是由于js是弱類型的動態語言,V8很快就觸碰到了性能優化 的天花板,因為很多場景下還是免不了recompile的過程。WebAssembly提供工具將各種語言轉換成特定的字節碼,瀏覽器直接面向字節碼編譯 程序。其實在此之前,firefox已經搞過asm.js做類似的事情,只不過WebAssembly的方案更激進。有人認為WebAssembly可能 是2016年最大的黑馬,如果wa能發展起來,若干年后我們看js編寫的應用會像現在看匯編語言寫出的大型程序的感覺。WebAssembly項目目前由 蘋果、谷歌、微軟、Mozila四大瀏覽器廠商共同推進,還是非常值得期待的(寫不下去了我決定回去翻開我那本落灰的編譯原理。。)。

Web Components

webcomponents規范起草于2013年,w3c標準委員會意圖提供一種瀏覽器級別的組件化解決方案,通過瀏覽器的原生支持定義一種標準化 的組件開發方式。webcomponents提出之際引發了整個前端圈的躁動,大家似乎在跨框架的組件化方案上看到了曙光。但是前端這圈子發展實在太特么 快了,在當前這個時間點,webcomponents也遭遇到了跟Object.observe相似的尷尬處境。我們先來看看webcomponents 的幾個核心特性:

  1. Shadow DOM

  2. Custom Element

  3. Template Element

  4. HTML Imports

其中1、4現在都能很容易的通過自動化的工程手段解決了(shadow dom對應的是scoped css),而自定義標簽這種事情不論是React還是Angular這類組件框架都能輕松解決,那么我用你webcomponents的理由呢?

另外webcomponents將目標對準的是HTML體系下的組件化,這一點跟React比就相對狹隘了(但是這并不表明React把戰線拉的那么長就不會有問題)。

不過原生支持的跨框架的組件還是有存在的意義的,比如基礎組件庫,只是在當前來看web components發展還是有點營養不良。期待2016年能有實質上的突破吧。

架構的變化

2015年出現的新的技術及思路,影響最大的就是技術選型及架構了。我們可以從下面幾點來看看它對前端架構上都有哪些影響。

組件化

React的風靡使得組件化的開發模式越來越被廣大開發者關注。首先要肯定的是,組件化是一個非常值得去做的事情,它在工程上會大大提升項目的可維 護性及拓展性,同時會帶來一些代碼可復用的附加效果。但這里要強調的一點是,組件化的指導策略一定是分治(分而治之)而不是復用,分治的目的是為了使得組 件之間解耦跟正交,從而提高可維護性及多人協同開發效率。如果以復用為指導原則那么組件最后一定會發展到一個配置繁雜代碼臃腫的狀態。如果以組件的形態劃 分,可以分為兩個類型:基礎控件和業務組件。基礎控件不應包含業務邏輯不然達不到拿來即用的效果,因此它也會表現出可復用的價值,但是根本還是為了提高業 務組件的可維護性。至于業務組件,可復用的價值就很低了。

  1. 組件化指的是什么

    組件化這個詞,在UI這一層通常指“標簽化”,也就是把大塊的業務界面,拆分成若干小塊,然后進行組裝。

    狹義的組件化一般是指標簽化,也就是以自定義標簽(自定義屬性)為核心的機制。這也是我們通常認識的組件。

    廣義的組件化包括對數據邏輯層業務梳理,形成不同層級的能力封裝。它不一定是一個自定義語義標簽:它可以是一個包含邏輯(js)、樣式 (css)、模版(html)的功能完備的結構單元,也就是我們常“口口相傳”的模塊(從術語準確性的角度來看模塊這個描述并不合適,應該稱之為組件); 它也可以是一個單純的js,比如http組件這種純邏輯單元。嚴格從概念上來講,css跟html是不具備單獨/組合成一個組件的,它們不具備描述邏輯的 能力(非圖靈完備)。從這個層面來看,全組件化是沒有任何問題及疑義的。

  2. 是否需要全組件化

    我們通常說的組件指的是狹義上的組件,而且往往我們理解的全組件化也是建立在狹義的組件基礎上的,

    代表框架是React。React+Flux體系下,它提倡盡可能將頁面作細粒度的組件拆分,組件的數據全部由父級組件通過props傳遞而來。這本身是 一件非常有價值的事情,能有效的確保應用狀態的穩定及可預測性,但是應用一旦復雜龐大起來,組件樹變得“枝繁葉茂”導致葉子節點層級過深,當出現數據問題 時,我們必須一層層的回溯來定位bug。而且組件樹過于龐大也會增加組件之間的通訊負擔。從狹義的組件來看,我對全組件化是存懷疑態度的,工程上的成本太 高是最大的問題,而且大部分開發者很難拿捏合適的組件粒度,容易出現過細/過粗的拆分。很多場景其實并不適合實現成狹義上的組件,它以零散的模板的方式存 在更合適。

    但是如果從廣義的組件來看,全組件的意義是很大的,我們需要通過拆分頁面邏輯區塊的方式實現程序的解耦,從而提升應用的可維護性。

綜合來看,我覺得工程上更具可行的全組件化方案應該是:細粒度的基礎組件庫 + 粗粒度的模板/組件。

工程化

工程化是近年前端提到最多的問題之一,而且個人認為是當前前端發展階段最有價值的問題,也是前端開發通往工業化時代的必經之路。這里不贅述,有興趣的同學看我前陣子整理的一篇文章前端工程化知識點回顧

應用架構層 MVVM & Flux

MVVM想必大部分前端都耳熟能詳了,代表框架是angular、vue、avalon。angular在1.2版本之后加入了 controllerAs語法,使得controller可以變成一個真正意義上的VM,angular整個架構也才真正能稱之為嚴格的MVVM(之前只 能說是帶有雙向綁定的MVC/MVP)。

Flux是facebook隨React一并推出的新的(準確來說其實是改進的,并非原創)架構模型,核心概念是單向數據流。Flux實質上就是一個演進 版的中介者模式,不同的是它同時包裝了action、store、dispatcher、view等概念。關于Flux對應用分層、數據在不同層之間只能 單向流轉的方式我是很贊成的。應用的分層在業務稍復雜的應用中都是很有必要的,它更利于應用的伸縮及拓展,副作用是會帶來一定的復雜度(在我看來這點復雜 度根本就可以忽略不計)。

今年被黑的最多的前端主流框架莫過于angular了。老實講前端圈真的挺善變的,去年各種大會都在分享angular黑jquery,今年就變成了都在分享react黑angular了。黑的點大致有三:

  1. angular的部分實現太low

  2. 太多Java身上帶來的臭毛病(并沒有在黑Java)

  3. mvvm自身的缺陷

第一點第二點我并無異議。angular的臟值檢測機制相對于其他mvvm框架的雙向綁定實現方式確實不太優雅,同樣有硬傷的還有失敗的模塊語法及過多過于復雜的概念。但是對于第三點,我有不同的看法。

大多數人黑mvvm會以Facebook那張經典的flux vs mvc的圖為論據,對于雙向綁定造成的數據流紊亂及應用狀態的不確定導致問題定位困難的觀點我是認同的,這一點我也有切身體會,但是單純的這一點就足以否定mvvm么?就說flux比mvvm高明?

MVVM在富表格型(自造的詞[[160820]]) 應用開發效率上是高于Flux的,典型的就是一些后臺管控平臺。而且最重要的是,MVVM跟Flux并不互斥,我們在MVVM中照樣可以引入Flux中的 一些機制從而確保應用狀態的穩定。很多時候我們對于框架/架構的孰優孰劣的爭論是沒意義的,拋開業務場景談解決方案都是耍流氓。

業務數據層 Relay & falcor

這一層對大部分前端來說可能是比較新的概念,其實我們可以這樣理解:在一個完整的應用中,業務數據層指的就是數據來源,在angular體系中可以等同于ngResource模塊(準確來說應該是$http)。

Relay是f家推出的在react上應用GraphQL的框架,它的大致思路是:前端通過在應用中定義一系列的schema來聲明需要的接口數據結構, 后端配合GraphQL引擎返回相應的數據。整個事情對于前端來說意義簡直是跨時代的,工業化典范!不僅能極大提升前后端協同的開發效率,還能增加前端對 于應用完整的掌控力。但是目前來看問題就是實施過于復雜,而且還得后端服務支持,工程成本太高,這一點上Meteor顯然做的更好。

falcor則是Netflix出品的一個數據拉取庫,核心理念是單一數據源,跟Redux的單store概念一致。用法跟Realy類似,也需要前端定義數據schema。
另外還有一個新的W3C標準api:fetch,它的級別等同于XMLHttpRequest,旨在提供比ajax更優雅的資源獲取方式,目前幾個主流瀏覽器支持的都還不錯,也有官方維護的polyfill,幾乎可以確定是未來的主流數據請求api。

業務數據層是前端應用中比較新的概念,它的多元化主要會影響到應用的架構設計,這里不細講后面再來說。

新的編程范式

函數式編程(FP)

函數式編程(functional programming)是近年比較火爆的一個編程范式,FP基于lambda演算,與以圖靈機為基礎的指令式編程(Java、C++)有著明顯的差異。 lambda演算更關注輸入輸出,更符合自然行為場景,所以看上去更適合事件驅動的web體系,這點我也認同。但問題是,太多開發者看到redux那么火 爆就急著學redux用js去玩函數式,我覺得這個有待商榷。js作為一個以基于函數(scheme,父親)跟基于對象(Self,母親)的編程語言為藍 本設計然后語法又靠近Java(隔壁老王)的“混血”語言,你非得用它去寫函數式,是不是過于一廂情愿?尤其是在現在瀏覽器還不支持尾調用優化的情況下, 你讓那激增的調用棧可如何是好,如果你確實鐘情于函數式,可以去玩玩那些更functional的語言(Haskell、Clojure等),而不是從js入手。最近看到一個老外關于js 的函數式編程的看法,最后一句總結很精辟:Never forget that javascript hate you.

函數式響應型編程(FRP)

函數式響應型編程(functional reactive programming)不是一個新概念,但也不過是近兩年才引入到前端領域的,代表類庫就是ng2在用的rxjs。FRP關注的是事件及對應的數據流, 你可以把它看作是一個基于事件總線(event bus)的觀察者模式,它主要適用于以GUI為核心的交互軟件中。但FRP最大的困難之處在于,如果你想使用這樣的編程范式,那么你的整個系統必須以 reactive為中心來規劃。目前微軟維護的ReactiveX項目已經有各種語言的實現版本,有興趣的同學可以去了解下。

工具鏈的變化

去年最主流的前端構建工具還是grunt&gulp,2015年隨著react的崛起和web標準的快速推進,一切又有了新的變化。

webpack & browserify & jspm

webpack跟browserify本質上都是module bundler,差異點在于webpack提供更強大的loader機制讓其更變得更加靈活。當然,webpack的流行自然還是離不開背后的react 跟facebook(可見有個強大的干爹多么重要)。但是從現在HTTP/2標準的應用及實施進展來看,webpack/browserify這種基于 bundle的打包工具也面臨著被歷史車輪碾過的危機,相對的基于module loader的jspm反而更具前景(雖然現在使用前兩者的開發者都多于jspm)。

PostCSS & cssnext

PostCSS作為新一代的css處理器大有取Sass/Less而代之的趨勢,Bootstrap v5也有著基于PostCSS去開發的計劃。但從本質來講它又不算一個處理器,它更像是一個插件平臺,能通過配置各種插件從而實現預處理器跟后處理器的效果。
cssnext官方口號是“使用來自未來的語法開發css,就在今天!”,但是cssnext又不是css4,它是一個能讓開發者現在就享受最新的css語法(包括自定義屬性、css變量等)的轉換工具。這一塊筆者還沒有過具體實踐,暫不多言。

寫在最后

從前端的發展現狀來看,未來理想的前端技術架構應該是每一層都是可組裝的,框架這種重型組合的適用場景會越來越局限。原因在于各部件不可拆卸會增加 架構的升級代價同時會限制應用的靈活性。舉個例子,我有一套面向pc端的后臺管控平臺的架構,view層采用angular開發,哪天我要遷移到移動端 來,angular性能不行啊,我換成vue就好了。哪天覺得ajax的寫法太挫,把http層替換成fetch就好了。又有一天后端的GranphQL 平臺搭好了,我把ngResource換成relay就OK了。

這種理想的方式當然是完全正確的方向,但是目前來看它對 開發者/架構師 的要求還是太高,工業級別上一套帶有約束性的框架還是有相當的需求的(特別是當團隊開發者的水平良莠不齊時。當然我覺得更正確的方式是流程上有一套完整的 自動化方案用于確保團隊提交的代碼質量,只是目前基于動態分析的代碼質量檢測工具還沒有出現,而且估計很長一段時間內都不會有)。雖然美好但是組合的方式 也不是沒有問題,各種五花八門的搭配容易造成社區的分化跟內耗,一定程度上不利于整個生態圈的發展。

近年前端生態的野蠻發展影響最大的應該就是新產品的技術選型了,亂花迷人眼,我們很難設計出一套適應大部分場景、而且短時間內不會被淘汰的架構。前 端的變化太快通常會導致一些技術決策的反復,今天的最佳實踐很可能明天就被視為反模式。難道最合適的態度是各種保留各種觀望,以不變應萬變?在這一點上即 使如我這般在技術上一向激進的人都有點畏手畏腳了。那句話怎么說的來著?從來沒有哪個圈子像今天的前端一樣混亂又欣欣向榮了。有人說2015年或許是大前 端時代的元年,目前看來,如果不是2015,那么它也一定會是2016年。

最后引用計子winter的一句話作為結語吧:

前端一直是一個變化很快的職能,它太年輕,年輕意味著可能性和機會,也意味著不成熟和痛苦。我經常擔心的事情就是,很可能走到最后,我們會發現,我們做了很多,卻還是一無所獲。所幸至今回顧,每年還是總有點不同,也算給行業貢獻了些經驗值吧。

本文轉載自:https://github.com/kuitos/kuitos.github.io/issues/32

 

 

責任編輯:王雪燕 來源: oschina
相關推薦

2015-12-24 09:39:11

2015-12-25 10:39:04

2010-01-07 09:14:27

2015-03-30 09:59:08

移動開發APP趨勢

2011-11-10 09:32:23

Wi-Fi

2017-03-13 11:04:24

后端開發

2009-01-13 17:02:05

RIAFlashSilverlight

2009-11-05 14:01:57

網管軟件

2013-09-11 14:00:16

Windows 8.1

2010-12-21 09:27:52

2010開源

2011-06-23 12:02:43

SPARC云計算服務器

2015-12-31 09:30:50

云計算云計算市場Docker

2009-04-27 15:40:53

Linux技術熱點發展趨勢

2015-06-24 09:36:04

DockerCon 2Docker

2017-03-01 20:31:35

程序員

2017-03-06 09:06:13

2015-06-08 09:24:10

代碼代碼依賴

2018-06-26 10:18:02

華為生態之行華為ICT

2010-05-26 09:15:39

HTML
點贊
收藏

51CTO技術棧公眾號

男女视频网站在线观看| 久久久99免费视频| 大陆极品少妇内射aaaaa| 欧美特级特黄aaaaaa在线看| 一本色道久久综合| 亚洲社区在线观看| 中文字幕 欧美日韩| 俺来也官网欧美久久精品| 91麻豆精品秘密| 国产在线不卡精品| 中文字幕一区二区三区手机版| 亚洲免费观看高清完整版在线观| 欧美精品123区| av在线观看地址| аⅴ资源新版在线天堂| 粉嫩一区二区三区在线看| 人妖精品videosex性欧美| 欧美大片xxxx| 欧美猛男同性videos| 欧美一区二区视频在线观看| 99精品人妻少妇一区二区| 免费**毛片在线| 国产三区在线成人av| 国产精品免费在线播放| 中文字幕+乱码+中文乱码www| 欧美亚韩一区| www.欧美免费| 一区二区三区伦理片| 伊人久久大香线蕉av超碰| 欧洲av在线精品| 人妻av中文系列| 久草中文在线| 国产欧美视频在线观看| 国产一区不卡在线观看| 97人人爽人人爽人人爽| 久久蜜桃精品| 91国产精品电影| 欧美成欧美va| 婷婷六月综合| 中文字幕不卡在线视频极品| 屁屁影院国产第一页| 亚洲视频一起| 日韩视频一区二区三区| 成年网站免费在线观看| 91精品店在线| 91福利在线观看| jizzjizzxxxx| 亚洲色图官网| 欧美日韩亚洲高清| 91免费黄视频| 丁香花高清在线观看完整版| 一区二区三区**美女毛片| 手机在线视频你懂的| 97电影在线| 国产精品理论片| 亚洲不卡1区| 日本一级在线观看| 久久人人97超碰com| 精品免费日产一区一区三区免费| 刘玥91精选国产在线观看| 国产ts人妖一区二区| 999精品视频一区二区三区| 国产乱人乱偷精品视频a人人澡| 老司机精品视频在线| 国产精品视频一区国模私拍| 中文字幕欧美人妻精品一区蜜臀| 日本亚洲三级在线| 国产欧美一区二区三区在线| 在线免费a视频| 国产综合成人久久大片91| 国产精品视频在线播放| 日韩欧美一二区| 久久国产精品99久久人人澡| 噜噜噜天天躁狠狠躁夜夜精品 | 蜜桃精品成人影片| 国产精品极品在线观看| 亚洲精品视频免费| 性欧美13一14内谢| 不卡日本视频| 久久久精品在线| 91精品国产高清久久久久久91裸体 | 蜜桃av.com| 国产精品久久久久久麻豆一区软件| 日韩在线观看视频免费| 欧美精品一级片| 国产欧美成人| 国产精品视频免费在线| 国产aⅴ一区二区三区| 成人网在线免费视频| 免费成人看片网址| a视频网址在线观看| 亚洲日穴在线视频| 农民人伦一区二区三区| 日韩精品免费观看视频| 日韩欧美一二区| 亚洲精品理论片| 一区二区日韩欧美| 91黑丝高跟在线| 亚洲一二区视频| 波多野结衣中文字幕一区二区三区| 久久综合一区二区三区| 在线视频婷婷| 亚洲.国产.中文慕字在线| 一区二区三区韩国| 国产精品白浆| 最近2019好看的中文字幕免费| 久热这里有精品| 日韩福利视频导航| 官网99热精品| 色综合久久久久综合一本到桃花网| 一区二区欧美精品| 在线免费观看视频黄| 国产精品久久久网站| 搡老女人一区二区三区视频tv| 日韩欧美高清在线观看| 久久国产综合精品| 欧美日本韩国国产| 国产探花视频在线观看| 91精品国产综合久久久久久久久久| 最近中文字幕无免费| 中文av一区| 国产精品免费观看在线| 污视频在线免费| 亚洲欧美国产77777| 美女黄色片视频| 精品三级av| 久久中文字幕国产| 久久久久久久久久一级| 成人动漫中文字幕| 国内自拍中文字幕| 久久伊人国产| 亚洲色图综合网| 免费观看成人毛片| av不卡在线播放| 国产成人生活片| 成人综合日日夜夜| 中文字幕日韩综合av| 亚洲黄色免费观看| 9i在线看片成人免费| 国产91沈先生在线播放| 国产精品中文| 久久精品99久久久久久久久| 伊人成年综合网| 久久精品一级爱片| 亚洲色欲综合一区二区三区| 久久夜色电影| 欧美性受xxx| 西西人体44www大胆无码| 亚洲综合区在线| 熟妇女人妻丰满少妇中文字幕| 91精品观看| 成人有码视频在线播放| 免费网站免费进入在线| 欧美精品一级二级三级| 免费看一级黄色| 麻豆精品久久精品色综合| 亚洲欧洲另类精品久久综合| 国产原创一区| 久久精品国产欧美激情| 国产精品一品二区三区的使用体验| 国产精品灌醉下药二区| 中文字幕12页| 欧美国产另类| 国产富婆一区二区三区| www.色在线| 亚洲老板91色精品久久| 国产美女www爽爽爽| 国产精品国产自产拍高清av| 黄色小视频免费网站| 夜间精品视频| 成人av中文| 乱馆动漫1~6集在线观看| 亚洲最大中文字幕| 国产女无套免费视频| 亚洲综合色在线| av中文字幕免费观看| 麻豆一区二区在线| 今天免费高清在线观看国语| 国产精品xxxav免费视频| 日本久久久久久| 亚洲成人三级| 精品国产一区二区三区不卡| 欧美日韩一级黄色片| 国产精品国产三级国产aⅴ入口 | 大胆国模一区二区三区| 欧美国产日韩在线| 色视频精品视频在线观看| 在线观看亚洲精品| 欧美黄色一区二区三区| 久久理论电影网| 久久久久久久久久一区二区| 在线看片成人| 亚洲高清乱码| 亚洲一区二区三区四区电影| 欧美亚洲在线播放| 免费网站成人| 日韩精品视频免费在线观看| 国产又粗又长又大视频| 精品二区三区线观看| 欧美人与禽zoz0善交| 粉嫩久久99精品久久久久久夜| 国产性生交xxxxx免费| 午夜国产精品视频| 日韩精品欧美专区| 日韩精品三级| 国产精品xxxxx| 99色在线观看| 日韩亚洲国产中文字幕| 四虎精品在线| 911精品国产一区二区在线| 国产午夜在线播放| 亚洲日本电影在线| 在线视频第一页| av综合在线播放| 欧美精品色视频| 视频一区二区不卡| 免费看欧美黑人毛片| 日韩亚洲一区在线| 欧美在线日韩精品| 懂色av一区二区| 99电影网电视剧在线观看| 97成人超碰| 国产成人一区三区| 成人黄色动漫| 精品国产拍在线观看| 大胆av不用播放器在线播放| 日韩成人性视频| 国产普通话bbwbbwbbw| 日本久久电影网| 999这里只有精品| 亚洲午夜久久久久中文字幕久| 国产三级aaa| 中文久久乱码一区二区| 亚洲区自拍偷拍| 91久色porny| 一区二区免费在线观看视频| 国产成人精品免费网站| 午夜啪啪小视频| 另类人妖一区二区av| 亚洲一区日韩精品| 美女脱光内衣内裤视频久久网站| 韩国日本在线视频| 久久亚洲图片| 国产福利一区视频| 天堂一区二区在线| 人妻无码视频一区二区三区| 三级影片在线观看欧美日韩一区二区| 免费在线激情视频| 久久久久一区| 中文字幕第80页| 免费在线观看视频一区| 校园春色 亚洲色图| 久久99精品国产.久久久久久| 欧美特级aaa| 久久99精品国产麻豆婷婷| 在线视频一二区| 国产一区欧美日韩| 国产精品19p| 成人污视频在线观看| 亚洲精品乱码久久久久久久| 91亚洲精品久久久蜜桃| 少妇特黄一区二区三区| 久久九九全国免费| 九九九视频在线观看| 一色桃子久久精品亚洲| 欧美精品xxxxx| 午夜日韩在线电影| 精品国产免费观看| 一本久久精品一区二区| 五月婷婷激情五月| 欧美军同video69gay| 国产高清不卡视频| 精品国产髙清在线看国产毛片| 天天躁日日躁狠狠躁伊人| 亚洲人成电影在线| 在线观看二区| 欧美丰满少妇xxxxx做受| 国产资源在线观看入口av| 97色在线观看| 国产a亚洲精品| 亚洲一区二区免费| 精品淫伦v久久水蜜桃| 日韩久久精品一区二区三区| 亚洲欧美综合久久久| 日韩 欧美 视频| 日日夜夜精品视频天天综合网| 欧美激情国内自拍| 成人福利视频在线看| 伊人影院综合网| 亚洲亚洲精品在线观看| 奴色虐av一区二区三区| 日韩欧美一区二区久久婷婷| 你懂的视频在线播放| 久久亚洲国产成人| 欧美男人天堂| 91久久久久久久久久久| 日韩啪啪网站| 加勒比海盗1在线观看免费国语版| 亚洲看片一区| 黄色片免费网址| 久久久精品免费观看| 久久久久亚洲AV| 欧美日韩成人高清| 婷婷在线观看视频| 久久久99免费视频| japanese23hdxxxx日韩| 波多野结衣成人在线| 凹凸成人精品亚洲精品密奴| 精品视频在线观看一区| 精彩视频一区二区| 日本少妇高潮喷水xxxxxxx| 亚洲精品水蜜桃| 在线亚洲欧美日韩| 亚洲美女在线视频| 天天干在线视频论坛| 91精品视频免费观看| 狠狠操综合网| 青青青免费在线| 国产精品69毛片高清亚洲| 先锋影音av在线| 欧美日韩亚洲精品一区二区三区 | 26uuu亚洲电影| 91精品入口蜜桃| 欧美va久久久噜噜噜久久| 国产xxxxx在线观看| 成人av免费网站| 欧美日韩大片在线观看| 欧美日韩一区三区| 国产视频第一页在线观看| 韩国国内大量揄拍精品视频| 日韩高清一区| wwwjizzjizzcom| 国产乱子轮精品视频| 久久av红桃一区二区禁漫| 欧美午夜影院一区| 国产视频精选在线| 国产91亚洲精品| 九九视频精品全部免费播放| 久久网站免费视频| 99国产精品国产精品久久| www.天天色| 日韩成人性视频| 在线男人天堂| 久久青青草综合| 亚洲综合日本| 亚洲最大成人网站| 色网站国产精品| 国产精品一区二区三区四区色| 日本韩国在线不卡| 久久av资源| 91淫黄看大片| 国产精品剧情在线亚洲| 一级黄色大片免费观看| 日韩中文字幕网址| 国产精品视频一区二区三区| av不卡在线免费观看| 国产伦精一区二区三区| 欧美片一区二区| 亚洲第一视频网站| 在线天堂中文资源最新版| 欧美连裤袜在线视频| 日韩av在线发布| 国产一区在线观看免费| 91精品国产入口| 日韩免费影院| 国产手机精品在线| 免费在线欧美黄色| 日本精品久久久久中文| 欧美精品在线观看播放| 97超碰在线公开在线看免费| 国产精品日韩一区二区| 国产一区二区你懂的| 国产综合精品久久久久成人av| 欧美日产国产精品| 人人超在线公开视频| 另类欧美小说| 免费在线观看不卡| 欧美日韩国产精品一区二区三区| 亚洲国产精品女人久久久| 免费观看成人性生生活片 | 亚洲黄页一区| 中文字幕免费看| 欧美日韩一区在线观看| 日本成人不卡| 欧美一区亚洲二区| 国产乱对白刺激视频不卡| 婷婷激情五月网| 精品国产自在精品国产浪潮| 国产成人澳门| 日本a√在线观看| 亚洲综合色网站| wwwxxx在线观看| 国产视色精品亚洲一区二区| 免费一级片91| 日韩精品一区二区av| 日韩一区二区三区在线播放| 丁香婷婷成人| 日韩成人精品视频在线观看| 精品福利视频导航| 黄色网页在线观看|