本文实例实现的功能如下:注册页(Register.js),点击注册,跳到注册结果页(RegisterResult.js),并将注册的手机号传递过去,显示xx注册成功。
index.Android.js
'use strict'
import React, { Component } from 'react';
import { AppRegistry,Navigator,BackAndroid} from 'react-native';
var Register = require('./study/Register');
let RegisterResult = require('./study/RegisterResult');
var NaviModule = React.createClass({
//告知Navigator模块,我们希望在视图切换时,用什么效果
configureScene:function(route){
return Navigator.SceneConfigs.FadeAndroid;
},
//告知Navigator模块,我们希望如何挂接当前视图
renderScene:function(router,navigator){
this._navigator = navigator;
switch(router.name){
case "register":
return <Register navigator = {navigator}/>
case "registerResult":
return <RegisterResult telephoneNumber = {router.telephoneNumber} navigator = {navigator}/>
}
},
//React的生命周期函数---组件被挂接时调用
componentDidMount:function(){
var navigator = this._navigator;
BackAndroid.addEventListener('NaviModuleListener',()=>{
if (navigator && navigator.getCurrentRoutes().length > 1) {
navigator.pop();
return true;
}
return false;
});
},
//React的生命周期函数---组件被移除时调用
componentWillUnmount: function(){
BackAndroid.removeEventListener('NaviModuleListener');
},
render:function(){
return (
<Navigator
initialRoute = {{name:'register'}}
configureScene = {this.configureScene}
renderScene = {this.renderScene} />
);
}
});
AppRegistry.registerComponent('FirstDemo', () => NaviModule);
注册页(Register.js)
'use strict'
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
TextInput
} from 'react-native';
let Dimensions = require('Dimensions');
let totalWidth = Dimensions.get('window').width;
let leftStartPoint = totalWidth * 0.1;
let componetWidth = totalWidth * 0.8;
let Register = React.createClass({
getInitialState:function(){
return {
inputedNum :'',
inputedPW:'',
},
updatePW: function(newText){
this.setState({inputedPW : newText});
},
render: function() {
return (
<View style={styles.container}>
<TextInput style = {styles.numberInputStyle}
placeholder = {'请输入手机号'}
onChangeText = {(aa) => this.setState({inputedNum :aa})}/>
<Text style={styles.textPromptStyle}>
您输入的手机号:{this.state.inputedNum}
</Text>
<TextInput style={styles.passwordInputStyle}
placeholder = {'请输入密码'}
password = {true}
onChangeText = {(newText) => this.updatePW(newText)}/>
<Text style={styles.bigTextPrompt}
onPress = {this.userRegister}>
注 册
</Text>
</View>);
},
userRegister:function(){
this.props.navigator.replace({
telephoneNumber : this.state.inputedNum,
name: 'registerResult',
});
}
});
const styles = StyleSheet.create({
container: {
flex: 1,
flexDirection:'column',
justifyContent: 'center',
backgroundColor: '#F5FCFF',
},
numberInputStyle:{
top:20,
left:leftStartPoint,
width:componetWidth,
backgroundColor:'gray',
fontSize:20
},
textPromptStyle:{
top:30,
left:leftStartPoint,
width:componetWidth,
fontSize:20
},
passwordInputStyle:{
top:50,
left:leftStartPoint,
width:componetWidth,
backgroundColor:'gray',
fontSize:20
},
bigTextPrompt:{
top:70,
left:leftStartPoint,
width:componetWidth,
backgroundColor:'gray',
color:'white',
textAlign:'center',
fontSize:60
}
});
module.exports = Register;
注册结果页RegisterResult.js
'use strict'
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
TextInput
} from 'react-native';
let RegisterResult = React.createClass({
render:function(){
return(
<View style = {styles.container}>
<Text style = {styles.text}>
{this.props.telephoneNumber}注册成功
</Text>
</View>
);
}
});
const styles = StyleSheet.create({
container: {
flex: 1,
flexDirection:'column',
justifyContent: 'center',
alignItems:'center',
backgroundColor: '#F5FCFF',
},
text:{
flexWrap:'wrap',
backgroundColor:'gray',
fontSize:20,
paddingTop:10,
paddingBottom:10,
paddingLeft:25,
paddingRight:25
},
});
module.exports = RegisterResult;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
js,界面跳转,值传递
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“详解js界面跳转与值传递”评论...
更新日志
2025年10月27日
2025年10月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]