RN 的环境搭建和基础操作参照官方文档:查看
学习做一个 videoplay的 app
(更新中)
-
初始化项目
react-native init videoplay
-
然后在模拟器运行
-
使用官方实例学习 TabBarIOS: 查看
index.ios.js
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
TabBarIOS,
} from 'react-native';
var base64Icon = '';
class videoplay extends Component {
constructor(props) {
super(props);
this.state = {
selectedTab: 'redTab',
notifCount: 0,
presses: 0,
};
}
render() {
return (
<TabBarIOS
unselectedTintColor="yellow"
tintColor="white"
barTintColor="darkslateblue">
<TabBarIOS.Item
title="Blue Tab"
icon={{uri: base64Icon, scale: 3}}
selected={this.state.selectedTab === 'blueTab'}
onPress={() => {
this.setState({
selectedTab: 'blueTab',
});
}}>
</TabBarIOS.Item>
<TabBarIOS.Item
systemIcon="history"
selected={this.state.selectedTab === 'redTab'}
onPress={() => {
this.setState({
selectedTab: 'redTab',
notifCount: this.state.notifCount + 1,
});
}}>
</TabBarIOS.Item>
<TabBarIOS.Item
icon={require('./img/message.png')}
title="More"
selected={this.state.selectedTab === 'greenTab'}
onPress={() => {
this.setState({
selectedTab: 'greenTab',
presses: this.state.presses + 1
});
}}>
</TabBarIOS.Item>
</TabBarIOS>
);
}
}
AppRegistry.registerComponent('videoplay', () => videoplay);
出现报错
查错
因为tabbar.item必须全部有组件 需要给每个Tabar.item中返回一个组件
加上组件
改错
效果
当前index.ios.js
import React, { Component } from 'react';
import {
AppRegistry,
StyleSheet,
Text,
View,
TabBarIOS,
} from 'react-native';
var base64Icon = '';
class videoplay extends Component {
constructor(props) {
super(props);
this.state = {
selectedTab: 'redTab',
notifCount: 0,
presses: 0,
};
}
render() {
return (
<TabBarIOS
unselectedTintColor="yellow"
tintColor="white"
barTintColor="darkslateblue">
<TabBarIOS.Item
title="Blue Tab"
icon={{uri: base64Icon, scale: 3}}
selected={this.state.selectedTab === 'blueTab'}
onPress={() => {
this.setState({
selectedTab: 'blueTab',
});
}}>
<View style={styles.container}>
<Text>
tab1
</Text>
</View>
</TabBarIOS.Item>
<TabBarIOS.Item
systemIcon="history"
selected={this.state.selectedTab === 'redTab'}
onPress={() => {
this.setState({
selectedTab: 'redTab',
notifCount: this.state.notifCount + 1,
});
}}>
<View style={styles.container}>
<Text>
tab2
</Text>
</View>
</TabBarIOS.Item>
<TabBarIOS.Item
icon={require('./img/message.png')}
selectedIcon={require('./img/message_fill.png')}
title="More"
selected={this.state.selectedTab === 'greenTab'}
onPress={() => {
this.setState({
selectedTab: 'greenTab',
presses: this.state.presses + 1
});
}}>
<View style={styles.container}>
<Text>
tab3
</Text>
</View>
</TabBarIOS.Item>
</TabBarIOS>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
justifyContent: 'center',
alignItems: 'center',
backgroundColor: '#F5FCFF',
},
});
AppRegistry.registerComponent('videoplay', () => videoplay);
接下来去除 state 里面不用的代码
把 view 放进其他的 index.js 再导入index.ios.js 作为组件
引入 class
使用
改写 creation 下的 index.js
import React, { Component } from 'react';
import Icon from 'react-native-vector-icons/Ionicons'
import {
StyleSheet,
Text,
View,
ListView,
TouchableHighlight,
Image,
} from 'react-native';
class List extends Component {
// 初始化模拟数据
constructor(props) {
super(props);
const ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
this.state = {
dataSource: ds.cloneWithRows([
{
"thumb": "http://dummyimage.com/'200x100' /fac2d4 )",
"video": "http://v2.mukewang.com/c2ba38b4-3d56-4057-8877-63b1510a7d7c/L.mp4?auth_key=1482849494-0-0-49e7e1c7f68cdeefb516569b84713f3d",
"title": "Urpmh Wgbmjedbfz",
"_id": "450000197710261527"
},
{
"thumb": "http://dummyimage.com/'200x100' /1962f8 )",
"video": "http://v2.mukewang.com/c2ba38b4-3d56-4057-8877-63b1510a7d7c/L.mp4?auth_key=1482849494-0-0-49e7e1c7f68cdeefb516569b84713f3d",
"title": "Ayini Doplyi Wlkckalak Bxytjxdo",
"_id": "430000197201302112"
},
{
"thumb": "http://dummyimage.com/'200x100' /433741 )",
"video": "http://v2.mukewang.com/c2ba38b4-3d56-4057-8877-63b1510a7d7c/L.mp4?auth_key=1482849494-0-0-49e7e1c7f68cdeefb516569b84713f3d",
"title": "Dmcgk Huejehql Uspfj Hkduefbtq",
"_id": "81000019731118228X"
}
]),
};
}
renderRow(rowData){
return(
<TouchableHighlight>
<View style={styles.item}>
<Text style={styles.title}>{rowData.title}</Text>
<Image
source={{uri: rowData.thumb}}
style={styles.thumb}
/>
<Icon
name='ios-play'
size={28}
style={styles.play}
/>
<View style={styles.itemFooter}>
<View style={styles.handleBox}>
<Icon
name='ios-heart-outline'
size={28}
style={styles.up}
/>
<Text style={styles.handleText}>
喜欢
</Text>
</View>
<View style={styles.handleBox}>
<Icon
name='ios-undo-outline'
size={28}
style={styles.comment}
/>
<Text style={styles.handleText}>
评论
</Text>
</View>
</View>
</View>
</TouchableHighlight>
);
}
render() {
return (
<View style={{flex: 1, paddingTop: 22}}>
<ListView
dataSource={this.state.dataSource}
renderRow={this.renderRow}
/>
</View>
);
}
}
const styles = StyleSheet.create({
item:{
},
});
export default List
效果
然后添加样式
const styles = StyleSheet.create({
container:{
flex: 1,
backgroundColor: '#f5fcff'
},
header: {
paddingTop: 25,
paddingBottom: 12,
backgroundColor: '#ee735c'
},
headerTitle: {
color: '#fff',
fontSize: 16,
textAlign: 'center',
fontWeight: '600'
},
item:{
width: width,
marginBottom: 10,
backgroundColor: '#fff',
borderBottomColor: '#eee',
borderBottomWidth: 1,
borderTopColor: '#eee',
borderTopWidth: 1
},
thumb: {
width: width,
height: width*0.56,
resizeMode: 'cover',
},
title: {
padding: 10,
fontSize: 18,
color: '#333'
},
itemFooter:{
borderTopColor: '#eee',
borderTopWidth: 1,
flexDirection: 'row',
justifyContent: 'space-between',
backgroundColor: '#eee'
},
play: {
position: 'absolute',
bottom: 60,
right: 14,
width: 46,
height: 46,
paddingTop: 9,
paddingLeft: 18,
backgroundColor: 'transparent',
borderColor: '#aaa',
borderWidth: 1,
borderRadius: 23,
color: '#ed7b66'
},
handleBox:{
flexDirection: 'row',
padding: 10,
width: width*0.5-0.5,
justifyContent: 'center',
backgroundColor: '#fff'
},
handleText: {
paddingLeft: 12,
paddingTop: 2,
fontSize: 18,
color: '#333'
},
up: {
fontSize: 22,
color: '#333'
},
comment: {
fontSize: 22,
color: '#333'
},
});
效果
如果图片加载不出来 参考查看