仿京东移动端地址选择组件 mobile/pc
仿京东移动端地址选择组件 适配触屏和PC 有异步获取收货地址的方法 Install
npm install --save react-address-picker-cc Example
cd examples
npm start
Usage
import React, { Component } from 'react' import AddressPicker from 'react-address-picker-cc' import { district } from './district'; export default class Sync extends Component { state = { address: '', dataSource: district, selectedIdList: [340000, 341800, 341824] } showPicker = () => { this.ecRef.show() } hidePicker = () => { this.ecRef.hide() } onAddressChange = (selectedRows) => { this.setState({ address: selectedRows.map(item => item.areaName).join(','), selectedIdList: selectedRows.map(item => item.id), }) console.log('选择值:', selectedRows) } render () { const { dataSource, selectedIdList } = this.state return ( <div> <h1>同步获取</h1> <input onClick={this.showPicker} value={this.state.address} placeholder="请选择地区" readOnly style={{ width: '100%' }} /> <AddressPicker dataSource={dataSource} selectedIdList={selectedIdList} text='这是收货地址组件' ref={e => (this.ecRef = e)} onAddressChange={this.onAddressChange} onClose={this.hidePicker} /> </div> ) } } Props
属性名 | 类型 | 默认值 | 描述 |
---|---|---|---|
title | String | node | 配送至 | 标题 |
className | String | 跟节点class | |
dataSource | array | 数据源 | |
onClose | Function | 关闭时回调函数 | |
onAddressChange | Function | 选择完闭时的回调函数; (selectedRows) => {} | |
navTips | string | 请选择 | 下一项的提示文字 |
pickerStatusChange | Function | Picker展开收齐的回调;(status) => {} | |
selectedIdList | array | 初始化地址的id数组 | |
isAsyncData | boolean | 是否异步获取数据 | |
getOneLevelData | Function | 获取第二、三层数据的方法,isAsyncData后有效 并且以Promise的方式返回dataSource |
getOneLevelData
方法进行优化,注意要以Promise的方法返回 dataSource
v1.0.0 首次上线,包含异步获取收货地址、Touch切换
近期升级计划
尝试添加单元测试用例
测试场景
功能测试简单列举
外部设置
空
省级
县级
省市县切换
同级切换
10级别切换效果
触摸切换
上下级切换
小范围切换
升级过程bug列表,都已修复
小范围移动bug
同步,关闭重新打开的效果
只有一级的效果,”请选择“
参考链接
借鉴了同行的组件 react-picker-address
LicenseMIT © https://github.com/shenghanqin/
版权声明:
1、该文章(资料)来源于互联网公开信息,我方只是对该内容做点评,所分享的下载地址为原作者公开地址。2、网站不提供资料下载,如需下载请到原作者页面进行下载。