react native toast (ios&android)

QQ20181217-160818-HD.gif

今天我?guī)砹薗uark瀏覽器的toast

設(shè)置:

  • position => 位置
    ToastPosition.top
    ToastPosition.center
    ToastPosition.bottom默認(rèn)??
  • duration => 時(shí)間
    DURATION.LENGTH_SHORT2秒
    DURATION.LENGTH_NORMAL3秒 默認(rèn)??
    DURATION.LENGTH_LOG4秒

使用方式

DeviceEventEmitter.emit('toast', 'show toast')

<NurToast
    duration={DURATION.LENGTH_NORMAL}
    position={ToastPosition.center}/>
center.gif
<NurToast
    duration={DURATION.LENGTH_NORMAL}
    position={ToastPosition.top}/>
top.gif

你把這NurToast.js直接調(diào)用indexjs或者是mainjs 就OK了比如:

export default class index extends Component {
    render() {
        return (
            ...
  
                {/**就一行*/}
                <NurToast/>
            ...
    }
}

然后想顯示toast的時(shí)候通過DeviceEventEmitter.emit('toast', msj)這方法把信息發(fā)送到NurToast.js就好了

NurToast.js:

import React, {Component} from 'react'
import {DeviceEventEmitter, Dimensions, LayoutAnimation, Platform, Text, UIManager, View} from "react-native";

const window = Dimensions.get('window');

export const ToastPosition = {bottom: 8, center: 2.2, top: 1.2};
export const DURATION = {
    LENGTH_SHORT: 2000,
    LENGTH_NORMAL: 3000,
    LENGTH_LOG: 4000,
};
export default class NurToast extends Component {


    propTypes: {
        ...ViewPropTypes,
        position: PropTypes.number,
        duration: PropTypes.number,
    };

    // 構(gòu)造
    constructor(props) {
        super(props);

        this.toastCloseNum = 0;
        this.toastCloseNumOld = 0;
        // 初始狀態(tài)
        this.state = {
            toastR: window.width,
            toastMessage: ''
        };
    }


    componentDidMount() {
        this.toastListner = DeviceEventEmitter.addListener('toast', (text) => {
            this.showToast(text);
        })
    }

    componentWillUnmount() {
        this.toastListner && this.toastListner.remove();
        this.timer && clearTimeout(this.timer)
    }


    /**
     * show toast
     * @param msj
     */
    showToast(msj) {
        let state = this.state;
        if (!state.toastR && state.toastMessage !== msj) {
            this.toastCloseNum += 1;
            this.anim();
            this.setState({
                toastR: window.width,
            });

            this.timer = setTimeout(() => {
                this.anim();
                this.setState({
                    toastR: null,
                    toastMessage: msj,
                });
            }, 300);
            this.closeToast();
        } else if (state.toastR) {
            this.toastCloseNum += 1;

            this.anim();
            this.setState({
                toastR: null,
                toastMessage: msj,
            });
            this.closeToast();
        }
    }

    /**
     * toast close
     */
    closeToast() {
        this.timer = setTimeout(() => {
            this.toastCloseNumOld += 1;
            if (this.toastCloseNumOld === this.toastCloseNum) {
                this.toastCloseNumOld = 0;
                this.toastCloseNum = 0;
                this.anim();
                this.setState({
                    toastR: window.width,
                });
            }
        }, this.props.duration || DURATION.LENGTH_NORMAL);
    }

    /**
     * set動(dòng)畫效果
     */
    anim() {
        if (Platform.OS === 'android') {
            UIManager.setLayoutAnimationEnabledExperimental(true);
        }
        LayoutAnimation.configureNext(LayoutAnimation.Presets.easeInEaseOut);
    }


    render() {
        return <View style={{
            backgroundColor: 'black',
            minWidth: 100,
            paddingRight: 20,
            paddingLeft: 10,
            paddingTop: 10,
            paddingBottom: 10,
            marginRight: 20,
            minHeight: 50,
            borderBottomRightRadius: 50,
            borderTopRightRadius: 50,
            position: 'absolute',
            justifyContent: 'center',
            right: this.state.toastR,
            alignItems: 'center',
            opacity: 0.9,
            bottom: (window.height / (this.props.position || ToastPosition.bottom)),
        }}>

            <Text style={{
                color: 'white',
                fontSize: 16,
                backgroundColor: 'transparent',
            }}>{this.state.toastMessage}</Text>

        </View>
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末艾栋,一起剝皮案震驚了整個(gè)濱河市义图,隨后出現(xiàn)的幾起案子偏竟,更是在濱河造成了極大的恐慌拟糕,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件亥曹,死亡現(xiàn)場(chǎng)離奇詭異隙轻,居然都是意外死亡访锻,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門因谎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來基括,“玉大人,你說我怎么就攤上這事财岔》缑螅” “怎么了?”我有些...
    開封第一講書人閱讀 162,823評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵匠璧,是天一觀的道長(zhǎng)揪阶。 經(jīng)常有香客問我,道長(zhǎng)患朱,這世上最難降的妖魔是什么鲁僚? 我笑而不...
    開封第一講書人閱讀 58,204評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮裁厅,結(jié)果婚禮上冰沙,老公的妹妹穿的比我還像新娘。我一直安慰自己执虹,他們只是感情好拓挥,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,228評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著袋励,像睡著了一般侥啤。 火紅的嫁衣襯著肌膚如雪当叭。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評(píng)論 1 299
  • 那天盖灸,我揣著相機(jī)與錄音蚁鳖,去河邊找鬼。 笑死赁炎,一個(gè)胖子當(dāng)著我的面吹牛醉箕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播徙垫,決...
    沈念sama閱讀 40,078評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼讥裤,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了姻报?” 一聲冷哼從身側(cè)響起己英,我...
    開封第一講書人閱讀 38,923評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎吴旋,沒想到半個(gè)月后损肛,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡邮府,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,550評(píng)論 2 333
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了溉奕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片褂傀。...
    茶點(diǎn)故事閱讀 39,727評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖加勤,靈堂內(nèi)的尸體忽然破棺而出仙辟,到底是詐尸還是另有隱情,我是刑警寧澤鳄梅,帶...
    沈念sama閱讀 35,428評(píng)論 5 343
  • 正文 年R本政府宣布叠国,位于F島的核電站,受9級(jí)特大地震影響戴尸,放射性物質(zhì)發(fā)生泄漏粟焊。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,022評(píng)論 3 326
  • 文/蒙蒙 一孙蒙、第九天 我趴在偏房一處隱蔽的房頂上張望项棠。 院中可真熱鬧,春花似錦挎峦、人聲如沸香追。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)透典。三九已至晴楔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間峭咒,已是汗流浹背税弃。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留讹语,地道東北人钙皮。 一個(gè)月前我還...
    沈念sama閱讀 47,734評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像顽决,于是被迫代替她去往敵國(guó)和親短条。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,619評(píng)論 2 354