摘要:但還存在一些問題,比如,單向數(shù)據(jù)流導(dǎo)致的有時(shí)數(shù)據(jù)鏈過長過繁瑣所以才產(chǎn)生了,需要在多地保存同一份數(shù)據(jù)等等。數(shù)據(jù)流細(xì)粒度的目前來說,我們的的甚至是還是設(shè)計(jì)得太過簡單。
前言
??由于筆者對React的了解不深,即便算是學(xué)習(xí)React的時(shí)間,到目前也才剛剛半年,所以錯(cuò)誤不足之處還望指正。以下都是基于React 15(可能有些是16),webpack1進(jìn)行探討(注:未學(xué)習(xí)過Vue,Ng,Ember,Cycle,Immutable,Redux-Saga,Mobx,Observable,Rxjs等等,所以可能有些方面已經(jīng)被提及或者解決了,希望不要介意)。
正文本文的排版可能不那么正經(jīng),想到哪寫到哪,見諒見諒。
組件
JSX
備受關(guān)注(吐槽)的if問題: 要討論這個(gè)問題,首先要明白jsx是轉(zhuǎn)換的是什么,只有這樣,你才明白為什么不能在jsx里面寫if語句,switch語句,為什么只能寫表達(dá)式等等。好了,回到正題,我們困撓,那么其他的程序猿肯定也是這樣滴,那么正確的姿勢是什么呢?沒錯(cuò),提isssue&討論,我們先來看看已有的提出的一些方案(來自JSX的issue,其他的諸如三目,把邏輯提取出來寫在外面,多return方式,IIFE,do expression等等這里就不多說了):
NO.1
https://github.com/facebook/jsx/issues/65#issuecomment-254056396 This part only gets shown if myCondition is true
NO.2
https://github.com/facebook/jsx/issues/65#issuecomment-255465492(官方人員提出的,所以采用的概率稍微要高一點(diǎn),基于do expression)Hi! {if (bool)else }
NO.3
https://github.com/facebook/jsx/issues/65#issuecomment-255484351} else={ } /> function If(props) { const condition = props.condition || false; const positive = props["then"] || null; const negative = props["else"] || null; return condition ? positive : negative; } 當(dāng)然,新的語法就意味著新的符號(hào)(一般來說),所以這種變化不一定是好的,也不一定每個(gè)人都能接受。
比如bjrmatos說的
"It"s just JavaScript, not a template language" -> no need to replicate JS functionalities with custom syntax. That is the main benefit of JSX IMO, seriously is so easy to do this with js even if it looks "weird" (for me it is not weird, it is just the syntax of the language)
比如jmar777說的:
[if (condition)][/if] We instead need:
{ condition &&} { condition && } { condition && } If the condition itself gets more complex, then the code gets uglier, or alternatively we need to store the result to a temporary variable, which further increases the verbosity. I will note that this particular pain point would be eased by better support for fragments.
TBH I"ve never seen a specific proposal that I"m overly fond of, but inasmuch as branching logic is integral to all but the most trivial of rendered outputs, I think there"s a compelling case to be made for first-class support in JSX.
Atrribute autocomplete(這也是我們的愿望之一,畢竟可以減少很多無用功,代碼也更整潔)
render () { const { prop1, prop2, prop3 } = this.props return () } Or
render () { const { prop1, prop2, prop3 } = this.props return () } Instead Of
render () { const { prop1, prop2, prop3 } = this.props return () } 希望支持?jǐn)?shù)字attribute省略花括號(hào)
還有的人希望對于字符串類型的attribute,能夠省略引號(hào)。seb最后也解釋了為什么沒有允許可以對字符串屬性進(jìn)行簡寫(因?yàn)榇嬖趦煞N不同的語義,如果允許去掉,到底以哪個(gè)為準(zhǔn)呢)
https://github.com/facebook/jsx/issues/25#issuecomment-137224657 I think the conclusion is that since these forms are currently semantically different in JSX parsers: // Foo & Bar // Foo & Bar We should keep it consistent which would mean that this would also be different: // Foo & Bar // Foo & BarAttribute Destructuring
https://github.com/facebook/jsx/issues/76// 當(dāng)然也可以先解構(gòu)了再賦過去,不過那樣肯定是要麻煩一點(diǎn)。最后seb也說了,如果https://github.com/RReverser/es-borrowed-props這個(gè)提案有進(jìn)展的話就更好了
Attribute Or Children
寫過組件的同學(xué)應(yīng)該有時(shí)候會(huì)遇到這樣的情況,我們需要調(diào)用方傳過來一個(gè)組件,那么問題來了,這個(gè)組件到底是以children的形式還是props的形式傳過來呢?有時(shí)候我們只需要一個(gè)組件,那么都可以(當(dāng)然還有考慮語義和大家的慣性思維)。如果需要多個(gè)組件就不行了,就需要進(jìn)行抉擇,有時(shí)候明明覺得都該以children的形式傳進(jìn)來,但是無奈必須做出取舍。所以我們可以看到比如有些同學(xué)就提出了:
NO.1 attribute2Children模式
https://github.com/facebook/jsx/issues/65#issuecomment-254060186...
NO.2 style(其實(shí)也是attribute2Children模式)
https://github.com/facebook/jsx/issues/65#issuecomment-254100455 // or
關(guān)于bind的問題,目前都基本用class里用箭頭函數(shù)的方式了。但是依然存在一個(gè)問題,在某些情況下我們依然需要使用bind(當(dāng)然用閉包也可以,不過面臨的問題是一樣的)。比如,我們想給我們的處理函數(shù)傳遞參數(shù),我們就不得不使用諸如
這樣一看似乎還行,但是仍然存在一個(gè)問題(其實(shí)我們完全沒有必要考慮這些,因?yàn)閷π阅苷娴臎]啥影響,性能基本不會(huì)通過這些得到改善或者降低,但是本著深挖洞,廣積糧的精神,思考思考還是可以的)。什么問題呢,就是如果這個(gè)arg是一個(gè)函數(shù)或者說是包含函數(shù)的對象,那么兩個(gè)函數(shù)相等就能夠推導(dǎo)出他們真的相等嗎?或者說兩個(gè)函數(shù)不相等就能推導(dǎo)出他們真的不相等嗎?顯然不能這樣,因?yàn)楹瘮?shù)可能“不純”。這就給我們的判斷工作帶來了一定的影響,之前沒有出錯(cuò)過是因?yàn)槌鲥e(cuò)的幾率本身就很低,因?yàn)閜rops和state本身都是“純的”,沒有人會(huì)去手動(dòng)修改它(即直接賦值)。我們不那么認(rèn)真的來看一下下面的例子:
class Bar extends Component { shouldComponentUpdate (nextProps, nextState) { if (this.props !== nextProps) { // 問題就出在這里,假設(shè)此后我們需要調(diào)用p2 if (nextProps.p2 !== this.props.p2) { // 那么這里到底該返回true還是false呢 // 返回true,那如果p2()的值沒變怎么辦,算不算是一種浪費(fèi) // 返回false,那如果p2()的值變了怎么辦 } else { // 這里p2相等了,我們能在之后調(diào)用之前緩存的p2嗎(假設(shè)緩存過了,當(dāng)然緩存的前提一般都是pure的才能緩存哈)?也不能,因?yàn)閜2可能從一個(gè)“純”的變成“不純”的了。另外返回false還是true和上面的同理。 } // 所以最后我們會(huì)發(fā)現(xiàn),我們根本沒法判斷,因?yàn)槲覀儾恢纏2到底“純”還是“不純” } } render () { console.log(...this.props); return null; } } let externalData1 = "extenalData1"; setTimeout(() => externalData1 = "externalData2", 1000); let util = (...args) => utilFunc(...args, externalData1); class Foo extends Component { state = { arg1: "1", arg2: util("aa") } componentDidMount () { this.setState({ arg1: "2", arg2: util("bb") }); } handleSomething (...args) { console.log(...args); ...somethingElse } render () { const { arg1, arg2 } = this.state; return (); } }
組件
一般來說,我們將組件分為兩大類,即基礎(chǔ)組件與業(yè)務(wù)組件。在React中,基礎(chǔ)組件基本已由Ant Design(PC端)覆蓋完畢,將來可能會(huì)有一些變動(dòng)/更新,但是都不會(huì)太大?;诨A(chǔ)組件的封裝/改寫,依舊屬于基礎(chǔ)組件。業(yè)務(wù)組件基于基礎(chǔ)組件,此時(shí)就面臨一個(gè)非常重要的問題,數(shù)據(jù)/數(shù)據(jù)流相關(guān)的處理(這個(gè)后面再談)。除此之外,主要想提及一下,還應(yīng)該有一類組件,暫且稱之為邏輯組件,為什么要分出來呢,因?yàn)榇_實(shí)感覺這兩類都不太能準(zhǔn)確的描述它。比如,
表單。
我們從最簡單的說起。一個(gè)input,不包含任何聯(lián)動(dòng)。那么現(xiàn)在存在一個(gè)問題,就是每一個(gè)input我們都要建立與之對應(yīng)的onChange函數(shù)(假設(shè)我們每一個(gè)input都采用Controlled Components的形式,因?yàn)榭煽匦砸靡稽c(diǎn)。同時(shí)都有自己的邏輯,不單單是setState(e.target.value)),太麻煩了。理想的情況是怎么樣的呢,我們應(yīng)該可以采取動(dòng)態(tài)建立的方式,只需要提供字段名,自動(dòng)將值注入到state中,以及自動(dòng)在組件的this或者原型鏈上創(chuàng)建對應(yīng)的onChange函數(shù),然后再賦給input(當(dāng)然這樣的話基本上要完全依賴提供的組件庫,不能期望自己隨便寫一個(gè)input也能自動(dòng)達(dá)到這樣的效果)。
那么問題來了,這里需要加糖(使代碼更少)和defineProperty(或者Proxy)(使修改更直接方便)嗎,個(gè)人認(rèn)為,都不可。因?yàn)檫@都會(huì)增加debug的難度。我還是更傾向于前面提到的簡單封裝,然后還是用setState去改變字段?,F(xiàn)在流行的主要有antd的form以及redux-form。但是個(gè)人認(rèn)為這并不是最好的方式,因?yàn)楦杏X有點(diǎn)亂,舉個(gè)比喻的話,感覺有點(diǎn)像寫傳統(tǒng)的模板一樣,當(dāng)然,也許就是要專門治治我們這些處女座。
下面說說聯(lián)動(dòng)的情況。在以前(如jQuery),我們要處理聯(lián)動(dòng),必須手動(dòng)維護(hù)聯(lián)動(dòng)的關(guān)系,所以要么在onChange里面根據(jù)邏輯手動(dòng)觸發(fā)其他組件的更新,要么是采用after或者callback queue的方式,總之,重心是維護(hù)邏輯而不是數(shù)據(jù)。那么是否應(yīng)該存在一種方式,讓我們的重心靠到數(shù)據(jù)上面?這樣debug,開發(fā),維護(hù)都輕松一些。對于React應(yīng)用而言,天然的解決了部分問題。但還存在一些問題,比如,單向數(shù)據(jù)流導(dǎo)致的有時(shí)數(shù)據(jù)鏈過長過繁瑣(所以才產(chǎn)生了redux),需要在多地保存同一份數(shù)據(jù)等等。
以上僅僅是一些思考,關(guān)于表單的探索還沒有開始(因?yàn)槟壳氨韱蜗嚓P(guān)的需求還不是很多和復(fù)雜,過段時(shí)間研究研究之后希望能解決一些問題)。
Encapsulated Compose Or Custom Compose
舉例來說。例如響應(yīng)式,我了解到這個(gè)概念應(yīng)該是從bootstrap的柵格開始,到后面antd也有對應(yīng)的Grid系統(tǒng),包含了Row和Col。那么問題來了,當(dāng)實(shí)現(xiàn)一個(gè)響應(yīng)式列表或者table的時(shí)候,是否應(yīng)該自己去組合,即哪些地方寫個(gè)Row,然后下面的Col的sm,md等等依次是多少,挨著填進(jìn)去。還是說我們先把這些組合邏輯封裝好,比如:
const responsive = responsivelizeComponent({ xs: 1, sm: 2, md: 2, lg: 2, pc: 3 });
然后調(diào)用,傳入數(shù)據(jù),以及Row,Col對應(yīng)的組件:
{ responsive( list, () =>, // 這里如果C本身就是Row,那么就進(jìn)行props合并,如果不是Row,那么需要在處理的時(shí)候包裹在Row里面 () => - ) // Item同理,只是換成了Col }
Component Middleware: 我們知道,中間件的概念由來已久了(歷史就沒有去考證了,node也不熟悉就不談了哈哈)。在redux中,我們就可以創(chuàng)建一系列的中間件去處理我們的action。那么,組件是否也可以具備這樣的能力呢(即組件中間件)?答案是肯定的,decorator就是一個(gè)很好的例子,但是decarator與middleware還是存在一定的差距,一是書寫上不直觀/美觀(目前個(gè)人能忍受的就是最多1個(gè)@),二是控制的力度太小。三是沒有形成一個(gè)整體,各個(gè)部分只能跟自己的上游打交道。這些方面才剛剛開始探索,就不在大佬們面前介(zhuang)紹(bi)了。
數(shù)據(jù)流
Redux
細(xì)粒度的actionType:
目前來說,我們的action的type甚至是action還是設(shè)計(jì)得太過簡單。我們完全可以進(jìn)一步進(jìn)行設(shè)計(jì)來減少我們的工作量。比如,我們可以看到redux初始化store時(shí)的actionType為@@INIT,受此啟發(fā),我們完全可以自定義更復(fù)雜的actionType甚至action,配置中間件進(jìn)行處理。比如@@FOO@@BAR/xx_TODO,或者像官方例子中的那樣const CALL_API = symbol("CALL_API"); action = { [CALL_API]: {...} },然后建立與之對應(yīng)的middleware,從而減少reducer的數(shù)量。當(dāng)然這是一個(gè)開頭,復(fù)雜應(yīng)用應(yīng)該是存在很多個(gè)middleware進(jìn)行職能分工(沒有復(fù)雜應(yīng)用的經(jīng)驗(yàn),這里就不多說了)。
actionType可以與相應(yīng)的處理的函數(shù)的名字形成包含關(guān)系,減少switch里的case代碼量。比如,在reducers/foo.js中,聲明了一系列的handlexxxxType,那么我們可以在foo.js中import * as all from "./foo.js";,然后創(chuàng)建一個(gè)類似于mapActionTypeToHanleFunction的處理函數(shù)。這里就不用在每個(gè)case都去調(diào)用某個(gè)函數(shù)了。
一次用戶操作導(dǎo)致的多個(gè)位置的數(shù)據(jù)變動(dòng)是否都可以通過接連觸發(fā)不同的dispatch action來實(shí)現(xiàn)?答案是否定的,比如dispatch某個(gè)action,目的是刪除某個(gè)實(shí)體,但是同時(shí)sotre中其他某個(gè)地方存儲(chǔ)了這個(gè)id,或者說一個(gè)ids數(shù)組里包含了這個(gè)id,那么在這次dispatch完成之后的更新里就會(huì)出錯(cuò),所以我們不能再dispatch一個(gè)action去同步的刪除這些數(shù)據(jù)。我們只能在不同的reducer里面監(jiān)測第一個(gè)dispatch的action,然后處理。
還有一個(gè)就是群里工業(yè)聚大大提到的,action實(shí)際上和HTTP請求非常相似,能否用處理HTTP請求的方式去規(guī)劃redux?
Redux-Orm:顧名思義,這就是一個(gè)ORM庫(畢竟這是一個(gè)前端的數(shù)據(jù)庫嘛,之前想過redux配合indexDB,后面發(fā)現(xiàn)也不是很方便)。使用后的感受是,確實(shí)比純的redux方便一些(廢話,不然人家創(chuàng)建這個(gè)干嘛)。具體的比較等之后用了mobx,immutable和rxjs之后再放在一起比較吧。
React要想觸發(fā)更新只能采用setState(拋開forceUpdate不談),所以這就限制了我們修改數(shù)據(jù) -> 自動(dòng)觸發(fā)所有相關(guān)更新這種操作,其他的應(yīng)用我們可以記錄所以依賴于這個(gè)數(shù)據(jù)的組件,然后修改數(shù)據(jù)的時(shí)候依次觸發(fā)它們。但React的話要想實(shí)現(xiàn)這個(gè)就必須繞一個(gè)圈子,如redux方案。同時(shí)還存在一些弊端,比如:
一是依賴某個(gè)數(shù)據(jù)的明明只有A,B組件,為什么我還要挨個(gè)通知C,D組件,C,D組件明明是依賴于另外的數(shù)據(jù)的。即便react-redux內(nèi)部進(jìn)行了很多性能優(yōu)化來避免不必要的更新(實(shí)質(zhì)也就是盡量確保兩點(diǎn),一是我不需要的數(shù)據(jù)不應(yīng)該觸發(fā)我的更新,二是即便是我需要的數(shù)據(jù),沒變化的情況下也不應(yīng)該更新)。因?yàn)閞edux和react-redux是隔離的,redux就是一個(gè)數(shù)據(jù)(包裹/快遞)倉庫,當(dāng)有包裹來的時(shí)候,他可以在自己內(nèi)部對包裹進(jìn)行分類,把包裹放在指定的某個(gè)或某些區(qū)域(當(dāng)然數(shù)據(jù)天然是可copy很多份的,包裹只有一份,就不要糾結(jié)這個(gè)啦),然后呢,包裹要出庫該走倉庫的哪個(gè)門呢?不清楚。。type只是倉庫內(nèi)部分類時(shí)用于參考的一個(gè)東西,對外部并沒有作用。
所以它只能依次打開倉庫的所有門,拿上擴(kuò)音器大喊,倉庫包裹更新啦,快來看看你們那兒要不要搞些事情~,這里其實(shí)就存在一個(gè)問題,倉庫里哪塊區(qū)域的包裹更新了其實(shí)倉庫本身是可以知道的,但是目前他沒有做記錄,這就導(dǎo)致了收到通知之后的前來的公司又必須親自去倉庫里找自己需要的包裹(selector),與此同時(shí),倉庫也不能保證這批包裹屬于這一次包裹更新中的包裹(即selector出來的并沒有發(fā)生變化)。所以這就造成了資源的浪費(fèi),有可能一次dispatch最后倉庫里沒有任何包裹更新,倉庫也必須挨個(gè)打開出庫門。二就是前面提到的有更新也不應(yīng)該挨個(gè)打開出庫門。
因此,可能地更好的一種方式是。組件應(yīng)該把自身可能需要的包裹提前告訴倉庫,細(xì)粒度一點(diǎn)的,當(dāng)然既可以是就在type和包裹間建立一種映射關(guān)系,如{type: { name: "update_todo", from: this, need: ["foo", "bar"] }}(foo和bar是store中的某個(gè)key), 粗粒度的話(有些case可能不能這樣做),就不自己去添need參數(shù)了(但是還是要寫from),可以直接讓redux本身進(jìn)行統(tǒng)計(jì),因?yàn)橐粋€(gè)action導(dǎo)致了哪些reducer發(fā)生了變化這個(gè)它是能夠統(tǒng)計(jì)的(也不難,很早的版本中在combineReducer中就有hasChanged的flag了),最后也能形成一個(gè)type到need的映射。然后組件也把need參數(shù)傳給connect,同時(shí),redux內(nèi)部的listeners就不應(yīng)再是一個(gè)簡單的回調(diào)數(shù)組了,需要按need進(jìn)行歸類,這樣我們才能保證不是去通知每個(gè)subscribe了的組件,而是確實(shí)需要這次更新的我們才通知。還有就是,既然有了need,也不再需要selector了,我們在通知的時(shí)候就自動(dòng)在store中把對應(yīng)的need傳過去了。(這里需要注意到是,對于實(shí)體數(shù)據(jù),store存儲(chǔ)的數(shù)據(jù)肯定還是要normalize后的,不然數(shù)據(jù)冗余很嚴(yán)重,但是我們通知的時(shí)候沒有必要再denomalize解范式化或者說像傳統(tǒng)的挨個(gè)把外鍵轉(zhuǎn)換為實(shí)體,我們直接建立一個(gè)reducer存儲(chǔ)當(dāng)前的dispatch對應(yīng)的網(wǎng)絡(luò)請求的response)
另外這些方面徐飛叔叔的文章真的是寫得非常非常不錯(cuò),自己的想法很多時(shí)候就是小巫見大巫了,之后一定還是要抽空多琢磨幾遍。
CSS Modules全局與局部: 從整個(gè)項(xiàng)目來講,可以將第三方非CSS Modules模塊的css統(tǒng)一放在一個(gè)目錄下,不做CSS Modules處理。局部的話用global語法就行了。
模塊復(fù)用: 比如有兩個(gè)css模塊,a.css和b.css,我們知道,composes是給對應(yīng)的標(biāo)簽的class加上某個(gè)css類,而不是像傳統(tǒng)的使兩個(gè)類都具備同樣的規(guī)則。對于在業(yè)務(wù)組件中composed基礎(chǔ)組件這樣還好,但是如果是composes其他的業(yè)務(wù)組件,就會(huì)顯得有點(diǎn)怪怪的,比如
命名: 模塊化能一定程度上減少長命名,但是無法完全消除長命名。因?yàn)槿鄙傩枰?。比如一個(gè)組件內(nèi)的一個(gè)list,依然需要寫成list,list-item,相比以前,省去了xx-list中的xx。但有些情況下,比如item下面的內(nèi)容很少,就一兩個(gè),我們不想多帶帶提取出來,那么就得寫成list-item-xxx,確實(shí)看著有一點(diǎn)不美觀。
Css的模塊是否應(yīng)和js模塊耦合? 通常來說,我們一個(gè)css模塊會(huì)對應(yīng)一個(gè)js模塊(除去皮膚,改版這些)。但是除此之外,是否應(yīng)該存在多帶帶的CSS模塊,它們不屬于具體的某個(gè)基礎(chǔ)組件或者業(yè)務(wù)組件,而是共享給這些組件去使用或者說組合。目前這方面沒有實(shí)踐過,就不多說了。
Css Modules與React結(jié)合
目前已有的方案有react-css-modules以及babel-plugin-react-css-modules,它們的作者是同一個(gè)人,后者是前者的改進(jìn)版本,這位作者也是medium上那篇大家熟悉的stoping css in js的作者。
前者(react-css-modules)存在的問題有,一是性能,因?yàn)椴捎玫氖荋OC的模式,導(dǎo)致在生產(chǎn)環(huán)境每次渲染也要走一遍檢索css映射表的過程,造成性能損耗。二是書寫方式麻煩,即便用了decorator,也還是要老是重復(fù)同樣的代碼。三是某些情況下要在一個(gè)組件內(nèi)使用多次HOC,整潔性和方便性都不太好。這些在README中基本都有提到。還有就是不能寫空的css規(guī)則,內(nèi)部對此會(huì)拋出異常(之前被這個(gè)坑過,剛好那個(gè)時(shí)候的chrome版本吞錯(cuò),找了很久才發(fā)現(xiàn)是這里的問題)。后面跟作者交流了一下,提出了空的css規(guī)則的適用場景和初衷,所以在babel-plugin-css-modules中對于此采用警告而不再是拋出異常。
后者(babel-plugin-react-css-modules)基本上解決了上述提到的所有問題。但是還有一個(gè)地方值得思考一下,那就是import機(jī)制的問題,個(gè)人認(rèn)為還需要增加一種特性(可配置對于每個(gè)js模塊是否啟用),即import多個(gè)css也不需要指定importName,默認(rèn)后面的會(huì)覆蓋前面引入的css中的同名class,否則我們還是要寫成foo.a bar.b的形式,喪失了我們使用這個(gè)的部分初衷。
另外采用這樣方式暫時(shí)有個(gè)缺點(diǎn)就是IDE支持不好(沒有自動(dòng)補(bǔ)全提示),盡管7月份發(fā)布的最新版webstorm對原生的CSS Modules支持度更好了(style.這種方式后會(huì)有自動(dòng)補(bǔ)全的提示)。
其他npm是否應(yīng)該具備更強(qiáng)的約束?即語義版本號(hào)必須滿足語義所賦予的條件,從而讓打包的時(shí)候不會(huì)1.0.1和1.0.2都打包,應(yīng)該只打包1.0.2,那個(gè)依賴1.0.1的包轉(zhuǎn)而去依賴1.0.2,從而使得只打包一個(gè)。更有想法的是,上傳到npm上的包必須提供類似react-codemod的機(jī)制(這個(gè)確實(shí)很難,不知深度學(xué)習(xí)能否有幫助),從而可以讓所有使用這個(gè)包的應(yīng)用無痛自動(dòng)升級(jí),從而實(shí)現(xiàn)哪怕是有breaking change的版本更新,比如1.0.2變成1.1.0,最后也只會(huì)打包1.1.0。之前包括現(xiàn)在,這部分內(nèi)容都是通過changelog或者官網(wǎng)更新的方式發(fā)放出來。然后讓開發(fā)者自己去解決。
一個(gè)目錄下有多個(gè)js文件,此時(shí)一般會(huì)建立一個(gè)index目錄去導(dǎo)出這個(gè)目錄下所有js里的default以及普通export的變量(當(dāng)然前提是沒有重復(fù)的),目的是為了import的時(shí)候直接import index文件,避免去記憶某個(gè)變量在哪個(gè)js文件中。但是這樣有一個(gè)麻煩,那就是每次新增js文件的時(shí)候都需要記得去index進(jìn)行export。那么我們?yōu)槭裁匆限@北轍的去搞一個(gè)index文件呢,我們的目的不就是要import方便嗎,為什么不讓編譯器(其實(shí)webpack的alias也可以,但是畢竟是第三方,包括fb內(nèi)部也有自己的模塊導(dǎo)入系統(tǒng),但是弊端他們也說了)去自動(dòng)尋找包含我們要引入的那個(gè)變量都有哪些js文件然后給我們一個(gè)清單呢,就像JAVA的import機(jī)制那樣,按ctrl+shift+o自動(dòng)import,如有重復(fù)的會(huì)讓你選擇到底以哪個(gè)文件導(dǎo)出的為準(zhǔn)(當(dāng)然也有些特殊情況,比如我們需要用as取別名)。
越復(fù)雜的項(xiàng)目,粒度越小,耦合度越低的項(xiàng)目,組件的數(shù)量會(huì)成倍的增加,如fb就有3W個(gè)組件。那么,我們?nèi)绾闻袛嗄硞€(gè)組件我們或者別人或者團(tuán)隊(duì)之前是不是寫過,如果是,我們又如何知道這個(gè)組件的名字是什么,在哪個(gè)位置?(fb雖然有fbjs是開源的,但是那個(gè)有點(diǎn)像util,而不是component庫,所以也不知道內(nèi)部到底怎么搞的,之前也只是問過對于react源碼他們是不是有比較方便的管理工具,能夠快速定位某個(gè)功能或者名字或者注釋在哪個(gè)地方,得到的答案是,沒有)。
錯(cuò)誤處理(16beta昨天剛發(fā)布了,官方有文檔了,就看官方的啦),構(gòu)建,測試,體積優(yōu)化,部署以后再談了(其實(shí)是因?yàn)闆]什么經(jīng)驗(yàn))。嗯,這次就先這樣吧
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/84449.html
摘要:前端與狀態(tài)現(xiàn)在的前端開發(fā)中,對于狀態(tài)的管理是重中之重。有限狀態(tài)機(jī)那么如何更好的管理前端軟件的復(fù)雜度的狀態(tài)機(jī)思想給出了自己的答案。有限狀態(tài)機(jī)并不是一個(gè)復(fù)雜的概念簡單說,它有三個(gè)特征狀態(tài)總數(shù)是有限的。 前提 在現(xiàn)在的前端社區(qū),關(guān)于MVVM、Model driven view 之類的概念,已經(jīng)算是非常普及了。React/Vue 這類框架可以算是代表。而自己雖然有 React/Vue 的使用經(jīng)...
摘要:是今年一定要學(xué)的東西這兩年頁面上用的三方組件多了,寫的少了,的一些屬性不太記得了,針對的學(xué)習(xí)計(jì)劃有兩個(gè)參照的樣式進(jìn)行學(xué)習(xí)參照的組件樣式,學(xué)習(xí)如何處理樣式與組件之間的關(guān)系,規(guī)范自己的寫法。 磕磕絆絆工作有幾年了,前端界幾乎每天都有新名詞,令人眼花繚亂,目瞪狗呆。這兩年一直在外包工作,業(yè)務(wù)寫的多些,對js的基礎(chǔ)掌握的還不是很到位。最近深感技術(shù)嗅覺遲鈍,雖然平時(shí)也有看書學(xué)習(xí),更多的時(shí)候都是斷...
摘要:后面會(huì)利用這個(gè)框架來做實(shí)踐。接下來就是我們要繼續(xù)探討的同構(gòu)同構(gòu)數(shù)據(jù)處理的探討我們都知道,瀏覽器端獲取數(shù)據(jù)需要發(fā)起請求,實(shí)際上發(fā)起的請求就是對應(yīng)服務(wù)端一個(gè)路由控制器。是有生命周期的,官方給我們指出的綁定,應(yīng)該在里來進(jìn)行。 眾所周知,目前的 WEB 應(yīng)用,用戶體驗(yàn)要求越來越高,WEB 交互變得越來越豐富!前端可以做的事越來越多,去年 Node 引領(lǐng)了前后端分層的浪潮,而 React 的出現(xiàn)...
摘要:明明如日中天,把它與倒過來,給加點(diǎn)東西或可與抗衡。在之后,大版本有十?dāng)?shù)個(gè),只有最近推的才回歸正常等后人總結(jié)歷史,無疑會(huì)把與之間的所有都稱為垃圾。讓網(wǎng)頁支持所見即得的可視化設(shè)計(jì),是框架的最高形態(tài),以前沒有類似工具,主要因?yàn)榧夹g(shù)做不到。 好吧,我承認(rèn)我是標(biāo)題黨。React 明明如日中天,把它與 Vue 倒過來,給 Vue 加點(diǎn)東西或可與 React 抗衡。不過,這兩年 Vue 干的正是這事...
閱讀 2833·2023-04-26 01:00
閱讀 763·2021-10-11 10:59
閱讀 2984·2019-08-30 11:18
閱讀 2683·2019-08-29 11:18
閱讀 1023·2019-08-28 18:28
閱讀 3019·2019-08-26 18:36
閱讀 2138·2019-08-23 18:16
閱讀 1072·2019-08-23 15:56