react-native

記一下從開(kāi)始到第一個(gè)項(xiàng)目中的問(wèn)題掸读。

01.expected a component class gotobject

importMessageDetailViewContainerfrom'./Messagedetail/MessageDetailViewContainer';

if(key ==='messageDetail'){

return

}

組件首字母要大寫(xiě)

02.dependencies與devDependencies的區(qū)別

devDependencies下列出的模塊,是我們開(kāi)發(fā)時(shí)用的依賴(lài)項(xiàng)蝗砾,像一些進(jìn)行單元測(cè)試之類(lèi)的包佑惠,比如grunt-contrib-uglify融欧,我們用它混淆js文件他炊,它們不會(huì)被部署到生產(chǎn)環(huán)境。dependencies下的模塊咧擂,則是我們生產(chǎn)環(huán)境中需要的依賴(lài),即正常運(yùn)行該包時(shí)所需要的依賴(lài)項(xiàng)檀蹋。

如果你將包下載下來(lái)在包的根目錄里運(yùn)行,執(zhí)行如下命令,默認(rèn)會(huì)安裝兩種依賴(lài)

npm install

如果你只是單純的使用這個(gè)包而不需要進(jìn)行一些改動(dòng)測(cè)試之類(lèi)的松申,只安裝dependencies而不安裝devDependencies。執(zhí)行:

npm install--production

通過(guò)“npm install

packagename”進(jìn)行安裝俯逾,只會(huì)安裝dependencies

npm installpackagename

如需安裝devDependencies贸桶,執(zhí)行:

npm installpackagename --dev

03.export default , export區(qū)別:import的時(shí)候export不帶{} export要帶{},export

default只能有一個(gè)

04.rest語(yǔ)法

functionanimals(...types){

console.log(types)

}

animals('cat','dog','fish')//["cat","dog","fish"]

而如果不用ES6的話桌肴,我們則得使用ES5的arguments皇筛。

05.()=>arrow function

不用指定this,當(dāng)我們使用箭頭函數(shù)時(shí)坠七,函數(shù)體內(nèi)的this對(duì)象水醋,就是定義時(shí)所在的對(duì)象,而不是使用時(shí)所在的對(duì)象彪置。并不是因?yàn)榧^函數(shù)內(nèi)部有綁定this的機(jī)制拄踪,實(shí)際原因是箭頭函數(shù)根本沒(méi)有自己的this,它的this是繼承外面的悉稠,因此內(nèi)部的this就是外層代碼塊的this宫蛆。

06.繼承

classAnimal{

constructor(){

? ? this.type ='animal'

}

says(say){

? ?console.log(this.type +' says '+ say)

}

}

letanimal =newAnimal()

animal.says('hello')//animal says hello

classCatextendsAnimal{

constructor(){

super()

?this.type ='cat'

}

}

let cat=newCat()

cat.says('hello')//cat says hello

constructor內(nèi)定義的方法和屬性是實(shí)例對(duì)象自己的,而constructor外定義的方法和屬性則是所有實(shí)例對(duì)象可以共享的的猛。

Class之間可以通過(guò)extends關(guān)鍵字實(shí)現(xiàn)繼承耀盗,這比ES5的通過(guò)修改原型鏈實(shí)現(xiàn)繼承,要清晰和方便很多卦尊。上面定義了一個(gè)Cat類(lèi)叛拷,該類(lèi)通過(guò)extends關(guān)鍵字,繼承了Animal類(lèi)的所有屬性和方法岂却。

super關(guān)鍵字忿薇,它指代父類(lèi)的實(shí)例(即父類(lèi)的this對(duì)象)。子類(lèi)必須在constructor方法中調(diào)用super方法躏哩,否則新建實(shí)例時(shí)會(huì)報(bào)錯(cuò)署浩。這是因?yàn)樽宇?lèi)沒(méi)有自己的this對(duì)象,而是繼承父類(lèi)的this對(duì)象扫尺,然后對(duì)其進(jìn)行加工筋栋。如果不調(diào)用super方法,子類(lèi)就得不到this對(duì)象正驻。

一個(gè)組件的組織結(jié)構(gòu)

1classdefinition

? ? 1.1constructor

? ? ? ? 1.1.1event handlers

? ? 1.2'component'lifecycle events

? ? 1.3getters

? ? 1.4render

2defaultProps

3proptypes

PropTypes和getDefaultProps()

1.一定要寫(xiě)PropTypes弊攘,切莫為了省事而不寫(xiě)

2.如果一個(gè)Props不是requied抢腐,一定在getDefaultProps中設(shè)置它

React.PropTypes主要用來(lái)驗(yàn)證組件接收到的props是否為正確的數(shù)據(jù)類(lèi)型,如果不正確襟交,console中就會(huì)出現(xiàn)對(duì)應(yīng)的warning迈倍。出于性能方面的考慮,這個(gè)API只在開(kāi)發(fā)環(huán)境下使用捣域。

基本使用方法:

propTypes: {

myArray: React.PropTypes.array,

myBool: React.PropTypes.bool,

myFunc: React.PropTypes.func,

myNumber: React.PropTypes.number,

myString: React.PropTypes.string啼染,

// You can chain any of the above with `isRequired` to make sure a warning

// is shown if the prop isn't provided.

requiredFunc: React.PropTypes.func.isRequired

}

假如我們props不是以上類(lèi)型,而是擁有復(fù)雜結(jié)構(gòu)的對(duì)象怎么辦竟宋?比如下面這個(gè):

{

text:'hello world',

numbers: [5,2,7,9],

}

當(dāng)然提完,我們可以直接用React.PropTypes.object,但是對(duì)象內(nèi)部的數(shù)據(jù)我們卻無(wú)法驗(yàn)證。

propTypes:{

myObject:React.PropTypes.object,

}

進(jìn)階使用方法:shape()和arrayOf()

propTypes:{

myObject:React.PropTypes.shape({

text: React.PropTypes.string,

numbers: React.PropTypes.arrayOf(React.PropTypes.number),

})

}

下面是一個(gè)更復(fù)雜的Props:

[

{

name:'Zachary He',

age:13,

married:true,

},

{

name:'Alice Yo',

name:17,

},

{

name:'Jonyu Me',

age:20,

married:false,

}

]

綜上丘侠,:

propTypes:{

myArray:React.PropTypes.arrayOf(

React.propTypes.shape({

name: React.propTypes.string.isRequired,

age: React.propTypes.number.isRequired,

married: React.propTypes.bool

})

)

}

07.如果想讓子view實(shí)現(xiàn)100%的效果可以設(shè)置left:0 ,right :0,同理height可以用top:0,bottom:0

08.使用text的numberOfLines可以實(shí)現(xiàn)文本截取省略號(hào)徒欣,即css的text-overflow屬性

09.react native里面沒(méi)有z-index的概念,是根據(jù)jsx語(yǔ)法里面定義組件的順序來(lái)實(shí)現(xiàn)的蜗字,后寫(xiě)的組件會(huì)覆蓋在先寫(xiě)的組件上

UIManager

模塊數(shù)據(jù)結(jié)構(gòu)打肝,JS端可訪問(wèn):

UIManager.[UI組件名].[Constants(靜態(tài)值)/Commands(命令/方法)]

從端上映射的方法:(部分)

·createView(int

tag, String className, int rootViewTag, ReadableMap props)

創(chuàng)建View

·updateView(int

tag, String className, ReadableMap props)

更新View

·manageChildren(int

viewTag, Array moveFrom, Array moveTo, Array addChildTags, Array addAtIndices,

Array removeFrom)

批量添加/刪除/移動(dòng)一個(gè)view下面的view

·measure(int

reactTag, Callback callback)

測(cè)量View的位置、size等挪捕,結(jié)果異步回調(diào)

·measureInWindow(int

reactTag, Callback callback)

測(cè)量View相對(duì)屏幕的位置粗梭、size等,結(jié)果異步回調(diào)

·dispatchViewManagerCommand(int

reactTag, int commandId, ReadableArray commandArgs)

派發(fā)View命令级零,也就是用來(lái)調(diào)用對(duì)應(yīng)View的方法

這個(gè)模塊是NativeModule方式定義的断医,在RN的JS端啟動(dòng)時(shí),端上會(huì)通過(guò)JSC把收集到的模塊信息(名稱(chēng))打到JS端全局變量global.__fbBatchedBridgeConfig中奏纪,并采用延遲加載策略:設(shè)置NativeModules.[模塊名]的getter鉴嗤,延遲通過(guò)JSC讀取模塊詳細(xì)信息(方法、命令號(hào)等信息)序调。在調(diào)用的時(shí)候會(huì)放到MessageQueue的隊(duì)列里醉锅,批量提交,兩次批量提交限制的最小間隔為5ms发绢。

10.NativeMethodsMixin?

react-native中直接訪問(wèn)原聲組件的方法

11.array.map(function(currentValue,index,arr),thisValue)

12.react-native沒(méi)有z-index的概念后寫(xiě)的組件在新寫(xiě)的上邊硬耍,所以一個(gè)view中放一個(gè)圖片view并不能擋住圖片超出view的部分。(為圖片設(shè)置與view一樣的style即可)

13.用循環(huán)渲染組件

會(huì)出現(xiàn)key的問(wèn)題例如Warning: Each child in an array or iterator should have aunique "key" prop. Check the render method ofListView.解決方法:為每個(gè)子組件添加key边酒,但是不能重復(fù)经柴。

14.Array.map()array.foreach()

優(yōu)先級(jí)map>foreach>for

foreach的返回值并不是數(shù)組,所以不能寫(xiě)鏈?zhǔn)酱a

15.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末墩朦,一起剝皮案震驚了整個(gè)濱河市口锭,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌介杆,老刑警劉巖鹃操,帶你破解...
    沈念sama閱讀 219,188評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異春哨,居然都是意外死亡荆隘,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)赴背,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)椰拒,“玉大人,你說(shuō)我怎么就攤上這事凰荚∪脊郏” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,562評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵便瑟,是天一觀的道長(zhǎng)缆毁。 經(jīng)常有香客問(wèn)我,道長(zhǎng)到涂,這世上最難降的妖魔是什么脊框? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,893評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮践啄,結(jié)果婚禮上浇雹,老公的妹妹穿的比我還像新娘。我一直安慰自己屿讽,他們只是感情好昭灵,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,917評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著伐谈,像睡著了一般烂完。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上衩婚,一...
    開(kāi)封第一講書(shū)人閱讀 51,708評(píng)論 1 305
  • 那天窜护,我揣著相機(jī)與錄音,去河邊找鬼非春。 笑死柱徙,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的奇昙。 我是一名探鬼主播护侮,決...
    沈念sama閱讀 40,430評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼储耐!你這毒婦竟也來(lái)了羊初?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,342評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎长赞,沒(méi)想到半個(gè)月后晦攒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,801評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡得哆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,976評(píng)論 3 337
  • 正文 我和宋清朗相戀三年脯颜,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片贩据。...
    茶點(diǎn)故事閱讀 40,115評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡栋操,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出饱亮,到底是詐尸還是另有隱情矾芙,我是刑警寧澤,帶...
    沈念sama閱讀 35,804評(píng)論 5 346
  • 正文 年R本政府宣布近上,位于F島的核電站剔宪,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏戈锻。R本人自食惡果不足惜歼跟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,458評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望格遭。 院中可真熱鬧哈街,春花似錦、人聲如沸拒迅。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,008評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)璧微。三九已至作箍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間前硫,已是汗流浹背胞得。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,135評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留屹电,地道東北人阶剑。 一個(gè)月前我還...
    沈念sama閱讀 48,365評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像危号,于是被迫代替她去往敵國(guó)和親牧愁。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,055評(píng)論 2 355

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