成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

基于react native的登錄界面demo 超簡易教程 redux版

scq000 / 609人閱讀

摘要:登錄視圖登陸失敗用戶名或密碼不能為空彈出提示框成功是點擊登錄按鈕后調(diào)用的函數(shù),這里的功能比較簡單。通過把發(fā)出去密碼登錄聲明組件需要整個中的哪一部分數(shù)據(jù)作為自己的將和組件聯(lián)系在一起編寫是負責生成的,所以在大項目中還會用到合并。

本豬說

本豬豬剛學react,也剛看RN,就叫寫這個,苦不堪言,搭環(huán)境就搭了好久??淳W(wǎng)上教程也是改了好多小地方才寫完了。本著雷鋒精神手把手教你寫(假的)。


環(huán)境以及版本

我用的是安卓模擬器跑的,不過應該ios也適配吧。
這是我的demo的配置依賴的版本

項目結構

紅色的框框是需要我們自己建立的,因為這個demo的action比較簡單,老師叫我把它寫在Login.js里面了,所以沒有寫在action文件里。

登錄視圖 screens/Login.js

import React, {Component} from "react";
import { StyleSheet,Text, TextInput, View, Image, TouchableOpacity, Dimensions,Alert} from "react-native";
import {connect} from "react-redux";

var {height, width} = Dimensions.get("window");

class Login extends Component {
    constructor(props) {
        super(props);
    }
    


----------


    onSubmit(userName,password){
        if(userName===""||password===""){
            Alert.alert("登陸失敗!用戶名或密碼不能為空");  //彈出提示框
        } else{
            // 成功
            Alert.alert("user: "+userName+" password:"+password);
        }
    }
   
    // onSubmit()是點擊登錄按鈕后調(diào)用的函數(shù),這里的功能比較簡單。這里輸入不為空都可以,之后的邏輯后面的事了,先讓我們?nèi)〉捷斎胫稻蚾k了

----------
    
    render() {
   
----------

        const {userName,password,dispatch} = this.props;
        
        //這個是es6的賦值語法。
        這里可以獲取到dispath,是因為我們在下面會用到**connect**封裝。
        當你用React Redux的connect進行封裝的時候,connect方法會把dispatch放到props中
----------

        return (
            
                
                {dispatch({type: "LOGINUSER", userName:userName})}}**
                />


----------
組件發(fā)出請求,也就是action。通過dispatch把action發(fā)出去


----------


                {dispatch({type: "LOGINPASS", password:password})}}**/>
                
                    登錄
                

            
        )
    }
}

const styles = StyleSheet.create({
    wrapper:{
        paddingTop:40,
        flex:1,
        alignItems:"center",
        // backgroundColor:"#444",
        backgroundColor:"#e7cbcb"
    },
    textInput:{
        backgroundColor:"#eee",
        borderColor: "gray",
        borderWidth: 2,
        width:width,
        height:60,
        marginBottom:10,
        textAlign:"center",
        fontSize:18
    },
    button: {
        backgroundColor: "#808182",
        // backgroundColor: "#64d0ee",
        height:60,
        width:width
    },
    buttonText: {
        color:"#fff",
        height:60,
        lineHeight:60,
        textAlign:"center",
        fontSize:18,
        fontWeight:"600"
    }
});

//聲明組件需要整個 store 中的哪一部分數(shù)據(jù)作為自己的 props
function selector(store) {
    return {
        userName:store.userName ,
        password:store.password
    }
}

//connect將store和組件聯(lián)系在一起
export default connect(selector)(Login);

編寫renducer reducers/LoginReducer.js

reducer是負責生成state的,所以在大項目中還會用到combineReducers 合并reducer。不過我們這個小,只有一個,就不用了。
ps:我這里后來改了個寫法,所以新增了一個文件。

LoginType.js

export const LOGINUSER= "LOGINUSER";
export const LOGINPASS="LOGINPASS";

reducers/LoginReducer.js (這里還裝了個依賴redux-actions)

import {handleActions} from "redux-actions";
import {LOGINPASS, LOGINUSER} from "./types/LoginType";

export default handleActions({
    [LOGINUSER] (state, action){
        return {
            ...state,
            userName:action.userName,
        }
    },
    [LOGINPASS] (state, action){
        return {
            ...state,
            password:action.password,
        }
    }
}, {
    userName:"",
    password:""
})

最后App.js 導入我們寫好的login組件和reducer

import reducer from "./reducers/LoginReducer";
import {Provider} from "react-redux";
import {createStore} from "redux";
import React, { Component } from "react";

import Login from "./screens/Login";


**let store = createStore(reducer);**

type Props = {};
export default class App extends Component {
    render() {
        return (
            **
                
            **
        )
    }
}

結語

這樣就完成這個demo了。我還在接著完善,現(xiàn)在在用react-navigation寫登錄跳轉(zhuǎn),loading啥的,所以也可以繼續(xù)關注哦,寫完了就放上來。
謝謝大噶看完了,一起繼續(xù)努力!越努力越幸運!

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/108679.html

相關文章

  • 微信應用號(小程序)資源匯總(1010更新)

    摘要:微信應用號小程序資源匯總。每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 wechat-weapp-resource 微信應用號(小程序)資源匯總。 每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 showImg(https://segmentfault.com/img/remote/1460000...

    趙春朋 評論0 收藏0
  • 微信應用號(小程序)資源匯總(1010更新)

    摘要:微信應用號小程序資源匯總。每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 wechat-weapp-resource 微信應用號(小程序)資源匯總。 每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 showImg(https://segmentfault.com/img/remote/1460000...

    piapia 評論0 收藏0
  • React項目實戰(zhàn):環(huán)境搭建

    摘要:官方文檔中文翻譯構建用戶界面的庫。官方文檔建議學習時以官方文檔為準,中文翻譯或者第三方作者的教程可以幫助你理清思路會用到的重要知識點我也會進行簡明的解釋,如遇到錯誤或者不理解的內(nèi)容,歡迎實時指出。 前言 前面提到前端大統(tǒng)一的概念,如果感興趣,歡迎說說自己的看法,點擊前往。Web前端框架層出不窮,不可能面面俱到,這里給個小建議: 如果對Weex App感興趣,應該選擇vue框架; 如果...

    cnio 評論0 收藏0
  • React項目實戰(zhàn):環(huán)境搭建

    摘要:官方文檔中文翻譯構建用戶界面的庫。官方文檔建議學習時以官方文檔為準,中文翻譯或者第三方作者的教程可以幫助你理清思路會用到的重要知識點我也會進行簡明的解釋,如遇到錯誤或者不理解的內(nèi)容,歡迎實時指出。 前言 前面提到前端大統(tǒng)一的概念,如果感興趣,歡迎說說自己的看法,點擊前往。Web前端框架層出不窮,不可能面面俱到,這里給個小建議: 如果對Weex App感興趣,應該選擇vue框架; 如果...

    GHOST_349178 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<