react native 快速上手策略(一)(新人注意事項(xiàng))

RN對(duì)于剛剛上手缆蝉,并且沒(méi)有接觸過(guò)相關(guān)編寫方式的新人來(lái)說(shuō)并不是十分的友好晓铆,至少我看來(lái)相關(guān)問(wèn)題的提問(wèn)都不多贮匕,所以一般遇到問(wèn)題想要百度解決姐仅,可以說(shuō)是非常難的一件事。

所以在這里將自己在學(xué)習(xí)以及使用RN時(shí)遇到的要點(diǎn)刻盐,跟大家分享掏膏,希望對(duì)剛接觸RN的人有所幫助吧恳谎。

首先有一點(diǎn)是需要明確的弥喉,接觸RN的時(shí)候就應(yīng)該摒棄掉那種,在百度上找滔韵,有了答案就盲目抄抄抄的想法乙墙,需要的是靜下心來(lái)颖变,好好探究一下這樣子做的目的到底是什么生均,哪怕你現(xiàn)在真的非常的趕。畢竟RN被提出來(lái)并且“貼在百度上”的問(wèn)題并不全面腥刹。

一马胧、npm intall 方式導(dǎo)入依賴出現(xiàn)wrong或warming

如果你在使用npm install方式下載依賴的時(shí)候出了問(wèn)題,紅色的wrong提示衔峰,在你不確定是否能夠正確使用時(shí)漓雅,你其實(shí)可以考慮使用官方推薦的yarn。

具體安裝方式看官網(wǎng)朽色,yarn add 代替了 npm install 的使用邻吞,所以你在下載組件的時(shí)候可使用:

yarn add react-native-xxx(這里是第三方租件)
等價(jià)于 npm install react-native-xxx

二、React Native使用第三方組件

使用第三方組件的時(shí)候需要注意葫男,剛起步的新人可能沒(méi)有上github的習(xí)慣抱冷,但其實(shí)github上面有相關(guān)組件的詳細(xì)介紹。你可以通過(guò)百度找到組件的名字梢褐,一般的旺遮,寫相關(guān)使用文檔的作者都會(huì)附上這個(gè)組件的github網(wǎng)址。去看看盈咳!看清楚相關(guān)的組件可能需要你在項(xiàng)目手動(dòng)加配置文件耿眉,也可以直接使用link,但是你可能會(huì)發(fā)現(xiàn)鱼响,項(xiàng)目啟動(dòng)會(huì)報(bào)無(wú)法解決依賴的錯(cuò)誤鸣剪,原因是在很多百度上的案例都沒(méi)有提及的。

但github上會(huì)有這么一個(gè)步驟:

項(xiàng)目目錄\android\build.gradle

allprojects {
    ......
    repositories {
        ......
        maven { url "https://jitpack.io" } //這個(gè)需要添加
    }
}

三丈积、setState是一個(gè)核心用法

基本上每一個(gè)新建的類文件筐骇,都會(huì)在構(gòu)造方法上創(chuàng)建this.state={},這里面的值江滨,是可以用setState進(jìn)行修改铛纬,且每次修改后,都會(huì)更新一次render唬滑,可以理解為頁(yè)面的刷新告唆。至于他是怎么更新的頁(yè)面這里有涉及到RN里Virtual Dom的相關(guān)原理,這里不做詳細(xì)介紹晶密,有興趣可以百度一下擒悬。

靈活的配合使用
this.state={}
this.setState({})

既然setState能夠控制頁(yè)面刷新,那就是很多的功能都需要靠這個(gè)方式去實(shí)現(xiàn)惹挟,舉一個(gè)最簡(jiǎn)單的例子:

做一個(gè)可收起與展示更多的按鈕

export default class TelescopicBtn extends Component{
  constructor(props){
        super(props);
        this.state = {
            state:0,
            subHeight:70,  //按鈕下方子模塊高度
            show:false,  //展開(kāi)或收起
            subTitle:'更多', //按鈕小標(biāo)題
        };
    }
  //點(diǎn)擊事件
  _telescopic = () =>{
        if(this.state.show){
            this.setState({
                subHeight:70,
                show:false,
                subTitle:'更多',
            })
        }else{
            this.setState({
                subHeight:140,
                show:true,
                subTitle:'收起',
            })
        }
    }
    render(){
        return(
                <TouchableOpacity
                    style={[styles.button,{backgroundColor:'white'}]}
                    onPress={()=>{this._telescopic();}}
                >
                    <View style={{flex:10,}}>
                        <Text style={styles.buttonTxt}>{this.props.name}</Text>
                    </View>
                    <View style={{flex:6,}}>
                        <Text style={{textAlign:'right',}}>
                            {this.state.subTitle}
                        </Text>
                    </View>
                </TouchableOpacity>
                <View style={[styles.subTool,{height:this.state.subHeight,}]}>
                    <View style={styles.oneItem}>
                       <Text>想要展示的內(nèi)容</Text>
                    </View>
                </View>
        )
    }
}
const styles = StyleSheet.create({
    button:{
        height:50,
        backgroundColor:'white',
        flexDirection:'row',
        alignItems:'center',
        justifyContent:'space-around',
        borderWidth:.3,
        borderColor:'#e0e0e0',
    },
    buttonTxt:{
        color:'black',
        marginLeft:5,
    },
    subTool:{
        backgroundColor:'white',
        borderBottomWidth:.3,
        borderColor:'#e0e0e0',
        overflow:'hidden',
    },
    oneItem:{
        flexDirection:'row',
        flexWrap:'wrap',
    }
});

在頁(yè)面渲染完成之后茄螃,每次點(diǎn)擊該按鈕缝驳,都會(huì)調(diào)用_telescopic()這個(gè)方法连锯,該方法更改this.state內(nèi)的參數(shù)归苍,使得高度以及小標(biāo)題改變,以此來(lái)達(dá)到收起與展開(kāi)的效果运怖。

小章結(jié)語(yǔ)

發(fā)起第一篇技術(shù)文章拼弃,也希望覺(jué)得不錯(cuò)的書(shū)友點(diǎn)個(gè)喜歡或是分享。以上是我的學(xué)習(xí)摇展、制作中遇到的難處以及自己的一些總結(jié)與理解吻氧,我會(huì)在往后的每一篇中提及三個(gè)新接觸RN時(shí)要注意的點(diǎn),如有不對(duì)之處歡迎大家的指正咏连,我都會(huì)虛心的請(qǐng)教嘿嘿嘿盯孙。
芥末的開(kāi)源RN:https://github.com/Eugenehyj/react-native-ShotTravelProject.git一個(gè)驢友圈分享功能,包括了后臺(tái)祟滴,使用文檔以及部分源碼還在完善之中振惰。
——“小白”的前端之路

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市垄懂,隨后出現(xiàn)的幾起案子骑晶,更是在濱河造成了極大的恐慌,老刑警劉巖草慧,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件桶蛔,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡漫谷,警方通過(guò)查閱死者的電腦和手機(jī)仔雷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)舔示,“玉大人朽寞,你說(shuō)我怎么就攤上這事≌独桑” “怎么了脑融?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)缩宜。 經(jīng)常有香客問(wèn)我肘迎,道長(zhǎng),這世上最難降的妖魔是什么锻煌? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任妓布,我火速辦了婚禮,結(jié)果婚禮上宋梧,老公的妹妹穿的比我還像新娘匣沼。我一直安慰自己,他們只是感情好捂龄,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布释涛。 她就那樣靜靜地躺著加叁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪唇撬。 梳的紋絲不亂的頭發(fā)上它匕,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音窖认,去河邊找鬼豫柬。 笑死,一個(gè)胖子當(dāng)著我的面吹牛扑浸,可吹牛的內(nèi)容都是我干的烧给。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼喝噪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼创夜!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起仙逻,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤驰吓,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后系奉,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體檬贰,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年缺亮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了翁涤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡萌踱,死狀恐怖葵礼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情并鸵,我是刑警寧澤鸳粉,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布,位于F島的核電站园担,受9級(jí)特大地震影響届谈,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜弯汰,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一艰山、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧咏闪,春花似錦曙搬、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)征讲。三九已至,卻和暖如春搂擦,著一層夾襖步出監(jiān)牢的瞬間稳诚,已是汗流浹背哗脖。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工瀑踢, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人才避。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓橱夭,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親桑逝。 傳聞我的和親對(duì)象是個(gè)殘疾皇子棘劣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345