摘要:登錄視圖登陸失敗用戶名或密碼不能為空彈出提示框成功是點擊登錄按鈕后調(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 () } } 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); {dispatch({type: "LOGINUSER", userName:userName})}}** /> ---------- 組件發(fā)出請求,也就是action。通過dispatch把action發(fā)出去 ---------- {dispatch({type: "LOGINPASS", password:password})}}**/> 登錄
編寫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
摘要:微信應用號小程序資源匯總。每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 wechat-weapp-resource 微信應用號(小程序)資源匯總。 每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 showImg(https://segmentfault.com/img/remote/1460000...
摘要:微信應用號小程序資源匯總。每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 wechat-weapp-resource 微信應用號(小程序)資源匯總。 每天不定期整理和收集微信小程序相關資源,方便查閱和學習,歡迎大家提交新的資源,完善和補充。 showImg(https://segmentfault.com/img/remote/1460000...
摘要:官方文檔中文翻譯構建用戶界面的庫。官方文檔建議學習時以官方文檔為準,中文翻譯或者第三方作者的教程可以幫助你理清思路會用到的重要知識點我也會進行簡明的解釋,如遇到錯誤或者不理解的內(nèi)容,歡迎實時指出。 前言 前面提到前端大統(tǒng)一的概念,如果感興趣,歡迎說說自己的看法,點擊前往。Web前端框架層出不窮,不可能面面俱到,這里給個小建議: 如果對Weex App感興趣,應該選擇vue框架; 如果...
摘要:官方文檔中文翻譯構建用戶界面的庫。官方文檔建議學習時以官方文檔為準,中文翻譯或者第三方作者的教程可以幫助你理清思路會用到的重要知識點我也會進行簡明的解釋,如遇到錯誤或者不理解的內(nèi)容,歡迎實時指出。 前言 前面提到前端大統(tǒng)一的概念,如果感興趣,歡迎說說自己的看法,點擊前往。Web前端框架層出不窮,不可能面面俱到,這里給個小建議: 如果對Weex App感興趣,應該選擇vue框架; 如果...
閱讀 2379·2021-11-11 16:54
閱讀 2631·2021-09-26 09:47
閱讀 3992·2021-09-08 09:36
閱讀 2742·2021-07-25 21:37
閱讀 934·2019-08-30 15:54
閱讀 2547·2019-08-30 14:22
閱讀 3256·2019-08-30 13:57
閱讀 2607·2019-08-29 17:17