在原生APP开发中,相信很多开发者都会见到这种场景:点击右上角更多的选项,弹出一个更多界面供用户选择。这种控件在原生开发中Android可以用PopupWindow实现,在iOS中可以用CMPopTipView,也可以自己写一个View实现。其类似的效果如下图所示:
实现思路分析:
要实现上面的视图,有很多种实现方式。前面的文章说过,要实现弹框相关的可以用React Native 提供的 Modal组件(Modal组件),使用Modal组件可以实现我们原生开发中的大多数效果。
要实现下拉三角,可以让美工切一个带下拉三角的背景,当然也可以自己通过ART实现(ART绘制)。对于选项卡的内容,在原生开发中为了适应更多的场景,我们一般会选择使用ListView组件,然后当点击某个Item的时候获得相应的属性即可。为了控制Modal的显示与消失,我们可以给Modal内置一个isVisible: this.props.show状态。
源码
要实现上面的效果,会这涉及到三个js文件:MorePopWidows.js、Utils.js、HomeActionBar.js,按照先后顺序,代码如下:
Utils.js
import {Dimensions} from 'react-native' const deviceH = Dimensions.get('window').height const deviceW = Dimensions.get('window').width const basePx = 375 export default function px2dp(px) { return px * deviceW / basePx }
MorePopWidows.js
import React from 'react' import { StyleSheet, Platform, View, Text, Image, TouchableOpacity, Alert, Modal, Dimensions, } from 'react-native' import SpacingView from "./SpacingView"; import QRScanPage from "../home/QRScanPage"; const { width, height } = Dimensions.get('window'); import px2dp from '../util/Utils' const mTop = px2dp(Platform.OS == "ios" "htmlcode">/** * https://github.com/facebook/react-native * @flow 首页的标题栏 */ import React, {Component} from 'react'; import {Platform, View, Dimensions, Text, StyleSheet, TouchableOpacity, Image} from 'react-native'; import SelectCityPage from '../home/SelectCityPage' import MorePopWidows from '../component/MorePopWidows' import px2dp from '../util/Utils' const isIOS = Platform.OS == "ios" const {width, height} = Dimensions.get('window') const headH = px2dp(isIOS "#666", marginLeft: 5}}>输入商家、商品名称</Text> </TouchableOpacity> <TouchableOpacity style={styles.action} onPress={() => { this.setState({ showPop: !this.state.showPop }) }}> <Image style={styles.scanIcon} source={require('../images/ic_scan_code_white.png')}/> <Text style={styles.scanText}>扫码</Text> </TouchableOpacity> </View> <View style={{ position: 'absolute', top: headH, left: 0, width: width, height: height }}> <MorePopWidows width={90} height={100} show={this.state.showPop} closeModal={(show) => { this.setState({showPop: show}) }} {...this.props}/> </View> </View> ) } render() { return ( <View> {this.renderHeader()} </View> ); } } const styles = StyleSheet.create({ headerStyle: { backgroundColor: "#06C1AE", height: headH, paddingTop: px2dp(isIOS ? 20 : 0), paddingHorizontal: 16, flexDirection: 'row', alignItems: 'center', }, searchBar: { width: width * 0.65, height: 30, borderRadius: 19, marginLeft: 10, flexDirection: 'row', justifyContent: 'flex-start', alignItems: 'center', backgroundColor: 'white', alignSelf: 'center', paddingLeft: 10, }, text: { fontSize: 16, color: '#ffffff', justifyContent: 'center', }, iconStyle: { width: 22, height: 22, }, action: { flexDirection: 'row', justifyContent: 'center', alignItems: 'center', }, scanIcon: { width: 28, height: 28, alignItems: 'center', marginLeft: 10, }, scanText: { fontSize: 14, color: '#ffffff', justifyContent: 'center', alignItems: 'center', }, });以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
暂无评论...
更新日志
2024年11月27日
2024年11月27日
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]