摘要:自己英語一般,水平有限,獻(xiàn)上原文地址,還有我翻譯的中文地址,歡迎大家勘誤下面是自己的一點感想先說一下,我們知道,前端優(yōu)化有這么幾步,第一步首先呢我們知道,一個應(yīng)用要依賴好多條文件,而瀏覽器加載完一條,要執(zhí)行完這條才加載下一條,所以呢,就很慢
自己英語一般,水平有限,獻(xiàn)上原文地址,還有我翻譯的中文地址,歡迎大家勘誤
下面是自己的一點感想先說一下webpack,我們知道,前端優(yōu)化有這么幾步,
第一步首先呢我們知道,一個應(yīng)用要依賴好多條js文件,而瀏覽器加載完一條,要執(zhí)行完這條才加載下一條,所以呢,就很慢,于是乎我們就得把它們合成一個,
第二步我們知道瀏覽器是有緩存的,那發(fā)布新版本的時候為了防止瀏覽器緩存,每次發(fā)新版本我們都得和上一版文件名不一樣,所以我們用md5摘要算法將js文件生產(chǎn)摘要,作為js文件名的一部分
第三步可是我們又想利用瀏覽器緩存,減少請求,加快加載速度,我們發(fā)現(xiàn)我們經(jīng)常改的是我應(yīng)用的業(yè)務(wù)邏輯部分的js,而js的依賴幾乎不該,而且js的依賴體積還不小呢。所以我們把js的所有的依賴放在一個文件(vendor.js)里,業(yè)務(wù)邏輯放一個文件(app.js)里,然后分別md5加密
第四步如果是是單頁應(yīng)用,而且又是一個比較龐大的應(yīng)用,一上來就把所有的js 都加載了,,是不是很浪費,因為很多頁面,我們都點不進(jìn)去啊。所以能我們需要按需加載。只有訪問要加載的頁面時,我們才加載相關(guān)js
第五步還是單頁應(yīng)用,為了加快第一次加載的速度,我們想如果要是css也能按需加載就好了,我們?yōu)槭裁床挥胘s動態(tài)按需加載css呢,干脆將css和js 寫一起(我們該怎么寫就怎么寫,讓webpack讓他們在一起),加載js就把css 加載了,一條js請求就同時里面包含css。。這樣css的請求也變少了,而且他倆可以一起用gzip壓縮
第六步圖標(biāo)什么的很多很雜有不大,我們是不是為了減少 請求數(shù)將他們合在一起啊。。生成雪碧圖。。對這還不夠完美。要是能和js在一起就更好了。。咋做呢。。用base64 讓他變成字符串。然后就能和js在一起了。這樣的話還可以利用gizp壓縮百分之75。不過前提是小圖片或者小圖標(biāo)。。不然。。。圖片太大的話還是。。
以上這6步。。webpack十幾行代碼就能幫你實現(xiàn)。demo看這里m.loutianxia.cn
我覺得性能大數(shù)據(jù)量高交互的應(yīng)用,同樣是兩個大牛,分別用react和angular,react會比angular性能好很多。注意我的前提哦,我用了一年半angular,最后還是被他的臟檢查,傷痛了心,我們知道一個雙向綁定就代表一個watch,就代表一串臟檢查,當(dāng)數(shù)據(jù)一大的時候。。唉。。。
最后是可維護型我先說一個結(jié)論單向數(shù)據(jù)流要比mvc強好多,
我會在我翻譯的redux教程中詳細(xì)說明
啰嗦這么多開始教程
教程 0 -介紹 為什么會有這個教程呢?當(dāng)我試著學(xué)redux的時候,我意識到通過依賴讀過的文章和個人經(jīng)驗學(xué)習(xí)到的有關(guān)flux的知識,存在很多錯誤的地方我不是說那些關(guān)于flux的文章不好只是我沒有正確掌握這些概念。
最終, 讓我僅僅只是會用不同flux框架(Reflux, Flummox, FB Flux)的文檔,和試圖將他們和我讀過的理論概念(actions / actions creators, store, dispatcher, etc)生搬硬套只有當(dāng)我開始用redux的時候,我才發(fā)現(xiàn)這個flux其實比我想象的簡單多了
,這多虧了redux擁有非常精良的設(shè)計而且不會向我以前以前用的那些框架一樣,有大量的“anti-boilerplate features”(反 范式 特征)現(xiàn)在 ,可以毫不夸張的說 我感覺通過redux學(xué)習(xí)flux比許多其他框架好多了。
用我自己的話講,這就是為什么我想把我掌握的和運用的有關(guān)redux的flux概念分享給大家的原因,你可能已經(jīng)知道下圖呈現(xiàn)的是著名的單數(shù)據(jù)流flux應(yīng)用
_________ ____________ ___________ | | | | | | | Action |------------?| Dispatcher |------------?| callbacks | |_________| |____________| |___________| ▲ | | | | | _________ ____|_____ ____▼____ | |?----| Action | | | | Web API | | Creators | | Store | |_________|----?|__________| |_________| ▲ | | | ____|________ ____________ ____▼____ | User | | React | | Change | | interactions |?--------| Views |?-------------| events | |______________| |___________| |_________|
在這個教程我們會逐步介紹給你以上圖表中的概念.我們會分別嘗試?yán)斫饷恳荒K存在的理由和扮演著一種什么樣的角色,
而不是上來就解釋整張圖,這樣大家都會頭大的 一旦你理解了每一部分,就能集齊龍珠,召喚神龍啦,哈哈哈
假設(shè)我們正在開發(fā)一個web應(yīng)用, 那么它是由啥構(gòu)成的呢?
1) Templates(模版) / html = View(視圖)
2) 和我們View(視圖層)里綁定的數(shù)據(jù)= Models (模型)
3) 取數(shù)據(jù)的邏輯, 調(diào)度切換各種視圖層,響應(yīng)用戶事件,數(shù)據(jù)的修改等= Controller(控制層)
這是我們所熟悉的非常經(jīng)典的mvc模式.想必你心中也有這樣的疑惑,如果在表達(dá)上稍作修改,其實mvc模式也很想flux的概念
Models 就像 stores
用戶事件,數(shù)據(jù)操作和數(shù)據(jù)修改就像 "action creators" -> action -> dispatcher -> callback
(view)視圖層 就像 React views
所以說,難道flux就僅僅是單詞而已嗎? 不是這樣的.但是這個單詞至關(guān)重要,
因為我們可以表達(dá)的更精準(zhǔn)一些通過這些術(shù)語(意思是說,,這么一比,難道flux僅僅是一個名字而已嗎,
其核心概念還和mvc一樣。不是這樣的,它其實和mvc思想是不同的。但flux的這個單詞也不能小覷哦,
因為它通過提出一些新的術(shù)語,可以更精準(zhǔn)的描述flxu這一架構(gòu)),舉個例子, 向后臺請求數(shù)據(jù)是可以稱為action, 就像一個點擊事件也是一個action,
input的change 事件也是一個action ...然后我們的操作都可以稱為action,action只是一個名字而已。
flux可以確保所有action都是由一個叫做dispatcher發(fā)出的 然后經(jīng)過我們的stores,最后通過監(jiān)聽store,發(fā)出一個通知。
而不是讓action直接修改你的Model層和View層(意思是說。。任何action,都必須通過dispatcher發(fā)起。
然后能引起stores改變,stores的改變會通知,再引起view的改變,而不像mvc那樣,一個事件過來了,
在這個事件的回調(diào)函數(shù)直接里改變model或者修改view)
我們將在mvc應(yīng)用中寫一個經(jīng)典的用例
1) 用戶點擊按鈕A
2) 按鈕A的點擊處理函數(shù)會觸發(fā)Model(模型) "A"的改變
3) Model"A"的改變,會使監(jiān)聽Model "A"的函數(shù)執(zhí)行,這個函數(shù)會觸發(fā)Model(模型) "B"的改變
4) Model"B"的改變,會使監(jiān)聽Model "B"的函數(shù)執(zhí)行,這個函數(shù)會觸發(fā) View B的 重新渲染
在這種環(huán)境下想要快速找到bug的源頭,那將是一個巨大挑戰(zhàn)啊.
這是因為View監(jiān)聽每一個Model,Model有監(jiān)聽其他的Model,
所以呢數(shù)據(jù)可以來自于很多地方又有可能因為可多情況被該改變掉(可能是因為views也可能是因為models)
(數(shù)據(jù)的改變可能來自于多種情況,很混亂,不可預(yù)測)
然后 當(dāng) 用flux以及它的單向數(shù)據(jù)流架構(gòu),上面的例子就變成這個樣子了
1) 用戶點擊按鈕A
2) 按鈕A的點擊處理函數(shù)會dispatch 一個action 出去,然后使 Store "A"接到通知發(fā)生改變
3) 用于 dispatch 出去的這個action也會通知其他的store,所以Store”B” 接到通知 也會做出相應(yīng)的 改變
4) Store "A",Store”B” 的改變 通知了 View B,使View B 發(fā)生重新渲染
所以知道我們?nèi)绾畏乐筍tore A 和 Store B產(chǎn)生直接聯(lián)系了吧 ?每一個store的修改只能通過action,
其他任何方式 都不可以的 (所以這樣就阻止你 watch Store A而直接改變Store B)
一旦和這個 acition有關(guān)的所有store 的都做出響應(yīng)的改變
views 最終也被更新了. 所以呢 數(shù)據(jù)只能沿著下面這條線傳遞:
action -> store -> view -> action -> store -> view -> action -> ...
就像我們的用例是從action開始一樣, 讓我們的教程也從action和創(chuàng)建一個action開始吧
未完待繼續(xù)翻譯
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/78334.html
摘要:前端日報精選譯中多樣的原理與跨域前端重構(gòu)感想創(chuàng)建一條通用鏈表在生產(chǎn)環(huán)境中直接部署代碼綁定過程和其中的一些坑的總結(jié)拖拽作業(yè)組件設(shè)計中文第期前端之切切切切切圖動畫實現(xiàn)菜單特效騰訊前端團隊社區(qū)布局探索之路依然最受歡迎,開發(fā)者年度報告還能 2017-10-14 前端日報 精選 [譯] Javascript 中多樣的 thisAJAX原理與CORS跨域前端重構(gòu)感想js創(chuàng)建一條通用鏈表在生產(chǎn)環(huán)境中...
摘要:如何在中使用動畫前端掘金本文講一下中動畫應(yīng)用的部分。與的快速入門指南推薦前端掘金是非常棒的框架,能夠創(chuàng)建功能強大,動態(tài)功能的。自發(fā)布以來,已經(jīng)廣泛應(yīng)用于開發(fā)中。 如何在 Angular 中使用動畫 - 前端 - 掘金本文講一下Angular中動畫應(yīng)用的部分。 首先,Angular本生不提供動畫機制,需要在項目中加入Angular插件模塊ngAnimate才能完成Angular的動畫機制...
摘要:單頁博客應(yīng)用編寫總結(jié)很久之前就想寫一個博客應(yīng)用在一開始想要直接用和模板直接寫但是暑假一開始的時候不小心入了的坑所以就一不做二不休直接用寫那既然用了不寫個單頁應(yīng)用也過意不去了不前前后后寫了將近兩個星期現(xiàn)在看來這其實是一個很容易的應(yīng)用但是鑒于 React-Express單頁博客應(yīng)用編寫總結(jié) 很久之前就想寫一個博客應(yīng)用.在一開始想要直接用express和ejs模板直接寫, 但是暑假一開始的時...
摘要:一般來說,聲明式編程關(guān)注于發(fā)生了啥,而命令式則同時關(guān)注與咋發(fā)生的。聲明式編程可以較好地解決這個問題,剛才提到的比較麻煩的元素選擇這個動作可以交托給框架或者庫區(qū)處理,這樣就能讓開發(fā)者專注于發(fā)生了啥,這里推薦一波與。 本文翻譯自FreeCodeCamp的from-zero-to-front-end-hero-part。 繼續(xù)譯者的廢話,這篇文章是前端攻略-從路人甲到英雄無敵的下半部分,在...
閱讀 2767·2021-11-24 10:23
閱讀 1164·2021-11-17 09:33
閱讀 2512·2021-09-28 09:41
閱讀 1427·2021-09-22 15:55
閱讀 3649·2019-08-29 16:32
閱讀 1916·2019-08-29 16:25
閱讀 1065·2019-08-29 11:06
閱讀 3431·2019-08-29 10:55