成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

關(guān)于單頁面應(yīng)用一些隨想

AaronYuan / 2645人閱讀

摘要:前面不短時(shí)間持續(xù)投入了時(shí)間在做應(yīng)用架構(gòu)方面的考量一個(gè)是冒險(xiǎn)進(jìn)行了一次應(yīng)用架構(gòu)的調(diào)整另一個(gè)是跟進(jìn)了的進(jìn)展當(dāng)然實(shí)際上是同一個(gè)事情也許錯(cuò)過的比收獲的還多一些不過能走到現(xiàn)在也算幸運(yùn)了畢竟單頁面應(yīng)用還面臨很多不成熟之處國慶長假過去不少現(xiàn)在的想法估計(jì)會(huì)

前面不短時(shí)間持續(xù)投入了時(shí)間在做 React 應(yīng)用架構(gòu)方面的考量
一個(gè)是冒險(xiǎn)進(jìn)行了一次應(yīng)用架構(gòu)的調(diào)整, 另一個(gè)是跟進(jìn)了 Redux 的進(jìn)展
當(dāng)然, 實(shí)際上是同一個(gè)事情. 也許錯(cuò)過的比收獲的還多一些
不過能走到現(xiàn)在也算幸運(yùn)了, 畢竟單頁面應(yīng)用還面臨很多不成熟之處
國慶長假過去不少現(xiàn)在的想法估計(jì)會(huì)淡忘了, 所以好歹留點(diǎn)筆記

我昨晚因?yàn)橐?Todolist 特意看了下 Wunderlist 里的拖拽效果
iPad 上搜 Todo 的時(shí)候還看見了上家公司 Appest 的應(yīng)用
當(dāng)時(shí)大概就是被 Backbone 折騰得身心俱疲, 也算挺無助的啦
還有老板 Facebook 的朋友來分享, 可惜跟 React 團(tuán)隊(duì)關(guān)系不大
想想 Todolist 依然是單頁面的標(biāo)志性的應(yīng)用, 各種 TodoMVC 層出不窮

大致兩年的時(shí)間, 社區(qū)的變化很不小了, 現(xiàn)在到處都是 React
除了 React Angular 其他的框架很少說, 特別 Backbone 幾乎沒影了
Vue 的作者分享的也都是 Meteor, 總之很多的概念都已深入人心
不過不變的大概是每年都會(huì)冒出大量的框架出來, 都不想去聽了
我參與社區(qū)的熱情也降低了, 也就論壇微博 QQ 群看人扯扯淡而已
時(shí)間也都放到公司產(chǎn)品還有自己的技術(shù)探索當(dāng)中, 也沒從前那種激情

一方面是工作久了, 接觸多了, 自己獨(dú)特的想法越來越少
無論想到什么, 都能想到說哪個(gè)新聞?dòng)刑徇^, 而且已經(jīng)很成型的想法
而且也來越認(rèn)識(shí)到底層原理的重要性, 漸漸苦惱算法跟編譯原理沒學(xué)好
雖然我也不指望學(xué)校能教好. 然而隨著框架規(guī)模擴(kuò)展, 少不了這些技能
或者僅僅是工作多了, 創(chuàng)意少了, 人變得圓滑, 或者成熟, 之類的

最初學(xué)習(xí) Backbone 的時(shí)候看到 MVC 和 MVVM 這些詞覺得高大上
后面翻多了資料, 發(fā)現(xiàn)存在 N 個(gè)版本的實(shí)現(xiàn), 概念都開始變混淆了
結(jié)果我又不肯花大工夫研究一遍每一種實(shí)現(xiàn), 最終看起來依然挺模糊
只是當(dāng)初 MVC 常常說的是數(shù)據(jù)和模板引擎分離, HTML 和 CSS 分離
有了 Virtual DOM 以后整個(gè)似乎變了, 是數(shù)據(jù)和 DOM 分離

原本是 Backbone 和 Handlebars 糾結(jié)著的組件復(fù)用問題
本來, Web Components 規(guī)范已經(jīng)讓人歡欣鼓舞了
誰知道了 Polymer 折騰了好久, 只是圍著 Google 自家搞得火熱
社區(qū)里遲遲沒進(jìn)展, 很快風(fēng)頭被 Facebook 搞出了 JSX 搶光了
Twitter 上 Polymer Summit 好像還蠻熱鬧, 但我們好像就沒動(dòng)靜

不過 React 軟肋還蠻明顯, 白天還聽同事說 Angular 的 Service 怎么完善
反觀 React, Flux 基本上被否了, 單項(xiàng)數(shù)據(jù)流的 Redux 成了熱門
然后呢, 開始對(duì)付網(wǎng)絡(luò)問題, 立馬分裂了, Relay 跟 Falcor 都不知道怎么跟
雖然單向數(shù)據(jù)流的原則已經(jīng)明確, 但是這種流中間各種異步怎么整
而且一下子連數(shù)據(jù)庫的奶酪都要去碰, 甚至牽涉到 N 種語言的開發(fā)實(shí)現(xiàn)
說實(shí)話我真不知道我們的數(shù)據(jù)層代碼怎么寫才是對(duì)的, 兩個(gè)方案都不能直接用

我在圍觀 Clojure 社區(qū)稀奇古怪的發(fā)明的時(shí)候, 總有種張牙舞爪的感覺
晚上看 Om 作者演講, 就說著 Relay 怎樣, Falcor 怎樣, Datomic 怎樣
然后前面兩個(gè)方案都否掉, 或者只是覺得不好, 開始大肆介紹 Datomic
然后就是 PHP 社區(qū)跟 Node.js 社區(qū)接受 Clojure 社區(qū)背后調(diào)戲的感覺
我也分辨不出來怎么才是對(duì)的, 然而總是覺得什么方案可肯定是存在問題的
無論 Relay 介紹自己的時(shí)候說自己怎么好, 換個(gè)社區(qū)就挑出很多刺了

從大體上說, 單頁面應(yīng)用演進(jìn)的方向還是明確的, 客戶端緩存同步數(shù)據(jù)
這個(gè)數(shù)據(jù)會(huì)越來越大, 需要在客戶端有數(shù)據(jù)庫管理, 當(dāng)然客戶端已經(jīng)這么做了
單頁面應(yīng)用能上不著天下不著地吊了好多年, 終于瀏覽器性能開始跟上
所以一個(gè)方向是整個(gè)客戶端方案在瀏覽器當(dāng)中重新用 JavaScript 造一遍
另一個(gè)是服務(wù)端渲染跟客戶端渲染無縫銜接, 一邊打開應(yīng)用一邊下載數(shù)據(jù)和代碼
對(duì)于二十年前設(shè)計(jì)的的語言來說, 硬件升級(jí)都變天了, 真夠嗆的

Web 這個(gè)奇葩的平臺(tái). 像 React 的代碼熱替換橫掃三個(gè)平臺(tái)的事情, 誰都想不到
本來還是編譯半天, 連前端開發(fā)應(yīng)用刷個(gè)很多秒, 前端建構(gòu)分鐘算的
突然一下子代碼熱替換又起來了, 還助推了一個(gè)很難上手的建構(gòu)工具
現(xiàn)在說 Webpack 已經(jīng)能搜到很多教程了, 連移動(dòng)端開發(fā)都沾上了邊
我還很短的代碼山寨完 Redux 和 redux-router, 自己都驚訝了
這些東西放在兩年前完全不會(huì)這么想, 也就當(dāng)蘋果設(shè)計(jì)師膜拜膜拜就完事的

因?yàn)殚_發(fā)的需要, 所以一直在追 Chrome 開發(fā)者工具新功能
相信每天看幾百遍的同學(xué)看到里邊多個(gè)奇怪功能心情跟我類似
每年 Addy Osmani 都放幻燈片和演講出來介紹, 晚上剛看新的幻燈片
能看出來前端開發(fā)對(duì)細(xì)節(jié)的要求已經(jīng)越來越精細(xì)了, 以及性能上關(guān)注
我在這方面大概剛起步, 只是開始初步對(duì)付過 React 組件優(yōu)化的坑
做了一輪以后對(duì) Chrome 開發(fā)工具的感想又上層了一個(gè)臺(tái)階, 功能太多

在最初學(xué)前端的時(shí)候動(dòng)畫是給我提供動(dòng)力的主要的因素, 因?yàn)楹每绰?br>然而說回到和游戲比起來, 應(yīng)用當(dāng)中的動(dòng)畫是小兒科了
我也看 Dribbble 上悶騷的人做的很多嚇壞程序員的 motion
或者看看 Mathbox 作者甩一堆的不知道超前幾年的動(dòng)畫
還有特別震撼的有人在 VR 當(dāng)中用 ClojureScript 和 Unity 搞的 live coding
應(yīng)用里的動(dòng)畫真是小兒科了, 而且偏偏已經(jīng)很小兒科還那么難寫
然后是各種兼容性問題, 或者奇葩的組件化問題, 我都不知道在干些什么

跟動(dòng)畫同樣郁悶的還有拖拽這種無比自然的交互方案
當(dāng)然, 更自然的是 Hololens 或者更早的第六感科技的手勢(shì)捕捉技術(shù)
總之, 在桌面瀏覽器上一般是沒有的事(這個(gè)也許是工作范圍的原因)
我到昨天細(xì)看了 Touch Events API 才了解兩者差別究竟怎樣
我已經(jīng)完全覺得鼠標(biāo)是個(gè)技術(shù)不足的時(shí)代的替代品了, 或者行業(yè)專用
有筆刻畫細(xì)節(jié), 有手勢(shì)快速交互, 為什么要用帶線的盒子在桌上摩擦

我回頭以短暫散亂的經(jīng)驗(yàn)揣度, 開發(fā)單頁面應(yīng)用需要投入研究些什么?
(1 怎樣管理大量的數(shù)據(jù), 瀏覽器中主要是緩存怎樣管理?
(2 怎樣處理異步的數(shù)據(jù), 瀏覽器中主要是請(qǐng)求和推送怎樣設(shè)計(jì)?
(3 怎樣做界面組件的抽象, 瀏覽器對(duì)應(yīng) Virtual DOM 和 CSS 怎樣拆分跟組合?
(4 怎樣豐富交互方式, 瀏覽器有點(diǎn)擊, 輸入, 文件拖放, 拖拽等等?
(5 怎樣設(shè)計(jì)好動(dòng)畫, 現(xiàn)在這樣 DOM 動(dòng)畫依靠各種類庫的情況下?
(6 上面的事情都做了, 然后性能跟兼容性怎么辦?

考慮到目前前端生態(tài)的混亂, 我認(rèn)為開發(fā)新工具來對(duì)付問題很重要
然而不管是跟進(jìn)他人的開發(fā)工具, 或者自己創(chuàng)建新的工具, 都非常困難
前面微博盛傳, 前端建構(gòu)工具兩三年已經(jīng)換的第三茬了
不過看看現(xiàn)在這茬, 被人吐槽配置太復(fù)雜啊, 很奇怪啊, 估計(jì)還得換
社區(qū)呼聲最高的編程語言了, 版本都刷到 2015 了, 語法很多認(rèn)不出來的
而未來的方向呢, WebAssembly, 我記得 ASM.js 才不久前的事情對(duì)吧
聽說 LLVM 后端已經(jīng)能生成了, 也有 C# 和 OCaml 的初步實(shí)現(xiàn)了

我大致覺得新技術(shù)有三個(gè)來源, 搞研究的, 為了團(tuán)隊(duì)里方便搞特殊的
還有明擺著是搞山寨的. 第三種主要是學(xué)習(xí)目的, 點(diǎn)個(gè)贊鼓勵(lì)下就算了
前兩種會(huì)是重要的模塊的來源, 只是前者容易理想化, 后者容易特殊化
實(shí)實(shí)在在開發(fā)出來, 同時(shí)自己團(tuán)隊(duì)能復(fù)用的, 比最初估計(jì)的少太多了
操作系統(tǒng)的代碼, 還算能廣泛使用, 然而開發(fā)成本一降 N 個(gè) Ubuntu 就冒出來了
對(duì)于前端的組件, 各種角色的人都能挑挑揀揀, 重用代碼的情況更需要考慮

我主要想說, 到后邊自己開發(fā)新東西, 新技術(shù), 必不可少的
當(dāng)然, 從理論層面說, 或者僅僅技術(shù)層面, 也不是真的嶄新的技術(shù)
世界上排除掉山寨語言的幾百種編程語言, 就是各種不同場(chǎng)景的取舍導(dǎo)致的
需要 A 語言的 b 特性, 需要 C 語言的 d 特性, 大量的取舍和權(quán)衡
所以單頁面的渾水, 幾個(gè)巨頭好像全摻合進(jìn)來了, 每個(gè)的方案還都不一樣
當(dāng)業(yè)務(wù)中需要一個(gè)功能, 跑到 React 的 Issue 列表去跪求, 不如自己做一個(gè)

我說這些的重點(diǎn)是, 并不是要用自己開發(fā)的技術(shù), 而是要有那個(gè)能力
就像美蘇冷戰(zhàn)要極力避免使用核武器, 然而沒有能力開發(fā)核武器就敗了
在這種時(shí)候才突然想起來算法不好, 編譯原理不行, 各種被大神耍著玩
社區(qū)一下開發(fā)新的數(shù)據(jù)結(jié)構(gòu), 一些給編譯器加語法, 過天換種編程模型
兩年時(shí)間從 Backbone 到 React, 以及語言, 模塊化, 改了一大片
更郁悶的是自己的能力遠(yuǎn)遠(yuǎn)不如那些朝三暮四改方案的框架開發(fā)者們
Angular 已經(jīng)改一大片, 如果 React 有一天也改了, 我沒辦法只能乖乖的

太年輕了, 看未來還是很迷茫的, 而且 VR 一出, 開發(fā)平臺(tái)也能改一大片
今年 Google IO 上有個(gè)分享也介紹過了, 連 Design Guidelines 都出了
我印象比較深說 VR 跟屏幕不一樣, 用戶可以隨意轉(zhuǎn)動(dòng)移動(dòng)的, 很難控制視野焦點(diǎn)
而且還要避免各種物體或者運(yùn)動(dòng)造成不適感, 還不能把人初始化在物體內(nèi)部
我記得 Mozilla 已經(jīng)有技術(shù)試驗(yàn) VR 了, 似乎相關(guān)標(biāo)準(zhǔn)有在推進(jìn)?
這樣的發(fā)展速度作為用戶蠻開心, 作為程序員我覺得壓力恐怕不會(huì)小

我個(gè)人觀點(diǎn), 在界面組件化方面 React 的 Virtual DOM 算是打贏這仗了
而它不擅長的數(shù)據(jù)加載, 還有動(dòng)畫, 依然存在巨大的想象空間
換個(gè)說法, 存在巨大的坑... 所有人走到這里, 要么繞不過去, 要么找別人搭的橋
至少對(duì)于單頁面應(yīng)用來說是這樣, 而且 Meteor 跟 Famo.us 兩座大橋
想想排列組合 famous-react, react-meteor, meteor-famous 挺滑稽了
然而誰知道我得在這個(gè)坑中間晃蕩多久呢, 到處是所謂新技術(shù)

短期想的還是跟進(jìn)技術(shù), 同時(shí)加強(qiáng)一下基礎(chǔ)吧, 特別是覺得 JavaScript 搖搖欲墜了
重要的是單頁面背后的數(shù)據(jù)庫原理, 數(shù)據(jù)界面方案, 編程語言底層, 總不至于松動(dòng)
偏偏這些東西好像是在張牙舞爪的 Clojure 社區(qū)的人手里攥著, 而且不夠?qū)嵱?br>David Nolen 每個(gè)演講我都有興趣聽, Rich Hickey 的更加是必須聽
對(duì)了 StrangeLoop 2015 大會(huì)總共超過 70 個(gè)視頻, 怎么可能看完!

全文完. 隨想帶了不少吐槽, 也不嚴(yán)謹(jǐn), 考慮涉及那么多術(shù)語也很難寫清楚了
有興趣的糾錯(cuò)的同學(xué)只求不要寫得像我這么粗略

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/86022.html

相關(guān)文章

  • 關(guān)于let的隨想

    摘要:塊狀作用域提起中的關(guān)鍵字,第一個(gè)想法就是塊狀作用域。而如果通過這些關(guān)鍵詞聲明的,那么也就會(huì)聲明到所在的作用域中。終于回到可以將變量綁定到所在的任意作用域中,通常是內(nèi)部。避免不必要的出現(xiàn)。 讀,想到哪里寫到哪里。。。 塊狀作用域 提起ES6中的let關(guān)鍵字,第一個(gè)想法就是塊狀作用域。 說到作用域,以前提及的都是全局作用域和函數(shù)作用域。當(dāng)進(jìn)行作用域查找的時(shí)候,永遠(yuǎn)是一層一層往上查找,直到找...

    zhangwang 評(píng)論0 收藏0
  • 代碼可讀性隨想

    摘要:例如,代碼傾向于使用駝峰命名,因此使用編寫代碼可以提供流暢的感覺這就可以起到可讀性的作用。這將極大地幫助你提高代碼的可讀性,因?yàn)槟闶紫葟睦斫忾_始,然后轉(zhuǎn)向性能。 原文:https://www.codecasts.com/blo... 本文探討編程中的一個(gè)術(shù)語:可讀性。 首先我們來談?wù)勊暮x: 可讀性是描述在其他開發(fā)人員沒有進(jìn)行太多聯(lián)想或猜測(cè)的情況下就能理解代碼的含義。為了讓其他的開...

    Object 評(píng)論0 收藏0
  • 代碼可讀性隨想

    摘要:例如,代碼傾向于使用駝峰命名,因此使用編寫代碼可以提供流暢的感覺這就可以起到可讀性的作用。這將極大地幫助你提高代碼的可讀性,因?yàn)槟闶紫葟睦斫忾_始,然后轉(zhuǎn)向性能。 原文:https://www.codecasts.com/blo... 本文探討編程中的一個(gè)術(shù)語:可讀性。 首先我們來談?wù)勊暮x: 可讀性是描述在其他開發(fā)人員沒有進(jìn)行太多聯(lián)想或猜測(cè)的情況下就能理解代碼的含義。為了讓其他的開...

    imingyu 評(píng)論0 收藏0
  • Java隨想 - 計(jì)算機(jī)的工作方式

    摘要:背景如圖所示馮諾依曼計(jì)算機(jī)體系結(jié)構(gòu)由于最近做業(yè)務(wù)需求做到發(fā)瘟借此發(fā)散一下思維最近業(yè)務(wù)需求的痛點(diǎn)如下基礎(chǔ)代碼骨架已固定業(yè)務(wù)流程固定然而業(yè)務(wù)中產(chǎn)品的配置需要非常靈活并且有可能需要跨過某段業(yè)務(wù)流程直接執(zhí)行下一段直接方案當(dāng)然是能夠決定條件分支的但架 showImg(https://segmentfault.com/img/bVbrHbo?w=1920&h=981); 背景 如圖所示, 馮諾依曼...

    DandJ 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<