当前位置: 首页 > news >正文

做网站 学什么万州网站建设

做网站 学什么,万州网站建设,电商网站开发岗位职责,网站延迟加载省市区三级联动选择是个很频繁的需求,但是查看了市面上很多插件不是太老不维护就是不满足需求,就试着实现一个 这个功能无任何依赖插件 功能略简单,但能实现需求 核心代码也尽力控制在了60行左右 pca-code.json树型数据来源 Administrative-d…

在这里插入图片描述
省市区三级联动选择是个很频繁的需求,但是查看了市面上很多插件不是太老不维护就是不满足需求,就试着实现一个
这个功能无任何依赖插件
功能略简单,但能实现需求
核心代码也尽力控制在了60行左右
pca-code.json树型数据来源 Administrative-divisions-of-China
下面只贴了省市区选择的功能,全部代码可参考github area分支

import { useState, useEffect } from 'react'
import { View, StyleSheet, FlatList, Text, TouchableOpacity } from 'react-native'
import pcaCode from "../assets/pca-code.json"export default () => {const [selected, setSelected] = useState([]) //选择过的省市区const [options, setOptions] = useState([pcaCode]) //每一级的数据const [level, setLevel] = useState(0) // 当前展示第几级useEffect(() => {console.log(selected)}, [selected])const renderItem = ({ item }) => (<TouchableOpacity style={styles.option} onPress={() => activeItem(item)}><Text style={[styles.option_text, isActive(item.code) && styles.option_text_active]}>{item.name}</Text>{isActive(item.code) && <View style={styles.option_icon} />}</TouchableOpacity >)const isActive = (code) => selected.some(item => item.code == code)const activeItem = (item) => {setSelected((prev) => {const newSelected = [...prev]newSelected[level] = { code: item.code, name: item.name }return newSelected.slice(0, level + 1)})if (level < 2) {const nextLevel = level + 1setLevel(nextLevel)setOptions((prev) => {const nextOptions = [...prev]nextOptions[nextLevel] = item.childrenreturn nextOptions})}}const PanelTab = () => {const tabs = selected.length < 3 ? selected.concat({ name: "请选择" }) : selectedreturn (<View style={styles.tab}>{tabs.map((item, index) => {return (<View style={styles.tab_item} key={index}><TouchableOpacity onPress={() => setLevel(index)}><Text style={item.code ? styles.tab_item_text : styles.tab_item_text_gray}>{item.name}</Text></TouchableOpacity>{level == index && <View style={styles.tab_item_line} />}</View>)})}</View>)}return (<><PanelTab /><FlatList style={styles.flat} data={options[level]} renderItem={renderItem} keyExtractor={item => item.code} /></>)
}const styles = StyleSheet.create({flat: {height: 500,},option: {height: 40,paddingRight: 15,flexDirection: "row",alignItems: "center",justifyContent: "space-between",},option_text: {fontSize: 14},option_text_active: {color: "#409eff",fontWeight: 'bold',},option_icon: {width: 6,height: 10,borderBottomWidth: 2,borderBottomColor: "#409eff",borderRightWidth: 2,borderRightColor: "#409eff",transform: "rotate(45deg)"},tab: {flexDirection: "row",marginBottom: 10,},tab_item: {position: "relative",marginRight: 15,},tab_item_text: {fontSize: 14,fontWeight: 'bold',paddingBottom: 10,},tab_item_text_gray: {fontSize: 14,color: "gray",paddingBottom: 10,},tab_item_line: {position: "absolute",bottom: 0,left: 0,width: "100%",height: 3,borderRadius: 5,backgroundColor: "#409eff"}
})
http://www.dt0577.cn/news/12474.html

相关文章:

  • 网站应该怎么做运维windows优化大师可以卸载吗
  • 企业做产品网站费用大概是多少核心关键词是什么意思
  • 西安网站制作工商国产搜什么关键词最好看
  • 做游戏模板下载网站有哪些内容大概需要多少钱
  • wordpress中文版河南网站关键词优化代理
  • 腾讯疫情实时更新seo整站优化报价
  • 福州最好的网站建设怎么做百度推广
  • 宝安营销型网站设计如何制作自己的网站教程
  • 床品图案设计网站洛阳seo网络推广
  • 个人网站 icp 代理信阳百度推广公司电话
  • 衡水做淘宝网站吴忠seo
  • 怎么看behance和其他设计网站备案域名
  • 做网站需要哪些框架好f123网站
  • win2003做网站seo搜索引擎优化实战
  • 深圳 seo 外贸网站建设 多语种杭州百度推广开户
  • 网站开发超链接点击后变色防疫优化措施
  • 4个月ui设计培训靠谱吗徐州seo管理
  • 企业网站后台管理系统模板青岛网站制作
  • 公司内网网站建设seo中文全称是什么
  • 深圳做自适应网站公司国内最新新闻消息今天的
  • 给素材网站做素材方法网站建设服务商
  • 怎么给网站做外链邵连虎珠海网络推广公司
  • 重庆公司网站建设价格推广论坛有哪些
  • 松桃县住房和城乡建设局网站百度搜索热度排名
  • 移动 网站模板百度外链查询工具
  • 做网站页面提供的图结构优秀软文范例100字
  • 织梦园模板网站免费b2b网站大全免费
  • 做网站要用服务器吗制作网站教程
  • 不用框架做网站北京网站
  • 公司做网站图片2023新一轮病毒叫什么名字