城市选择器小程序实现

1.效果图

2.使用方法

#  城市选择器, 城市数据库可自己导出

##后台数据API 由HotApp小程序统计提供并维护,如果需要导出并部署在公司的生产环境,最后有SQL导出下载地址

## 使用方法

- 复制pages/district到你的项目目录

- 把样式文件district.wxss引入到您调用本插件的作用域

`@import "你的路径/district/wxParse.wxss";`

- 在需要使用的模版的x.wxml中引入模版文件wxParse.wxml

```javascript

<import src="../district/district.wxml"/>

<template is="district" data="{{districts}}" />

```

- 在对应的js中引入district.js文件

`var WxParse = require('你的路径/district/district.js');`

- 使用:

在你的js文件中, 必须要绑定四个事件:  

getProvinces、getCities、getDistricts和finish  

其中  

getProvinces事件需要调用districts.getProvinces(this);  

getCities事件需要调用districts.getCities(this, event);  

getDistricts事件需要调用districts.getDistricts(this, event);  

finish事件需要调用districts.finish(this, event); 

 

## 数据来源

数据来源于高德地图, 从高德地图的行政区划查询中找到了api请求地址, 然后再写脚本把高德所有的数据全部导入到hotapp的数据库中

## 数据库表设计

高德地图返回的数据格式是:

```json

{

    adcode: "220100"

  center: "125.3245,43.886841"

  citycode: "0431"

  districts: []

  level: "city"

  name: "长春市"

}

```

 数据库字段设计为:

```sql

CREATE TABLE `tbl_districts` (

  `adcode` char(6) COLLATE utf8_unicode_ci NOT NULL,

  `name` varchar(20) COLLATE utf8_unicode_ci NOT NULL,

  `lng` decimal(12,8) unsigned NOT NULL,

  `lat` decimal(12,8) unsigned NOT NULL,

  `level` varchar(10) COLLATE utf8_unicode_ci NOT NULL,

  `parent_adcode` char(6) COLLATE utf8_unicode_ci NOT NULL,

  `created_at` timestamp NULL DEFAULT NULL,

  `updated_at` timestamp NULL DEFAULT NULL,

  PRIMARY KEY (`adcode`),

  KEY `tbl_districts_parent_adcode_index` (`parent_adcode`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

```

其中, lng表示经度, lat表示纬度, level有"province"、"city"和"district"三种类型


 

## 接口使用方法

一共就一个接口: `GET /districts`, 如果不带参数, 表示获取的是所有province级别的数据, 如果带上参数parent_adcode, 表示获取指定的parent_adcode的数据. 

比如: 要获取所有province级别的数据:返回格式为:

```json

[

  {

    "adcode": 110000,

    "name": "北京市",

    "lng": "116.40528500",

    "lat": "39.90498900",

    "level": "province",

    "parent_adcode": ""

  },

  {

    "adcode": 120000,

    "name": "天津市",

    "lng": "117.19018200",

    "lat": "39.12559600",

    "level": "province",

    "parent_adcode": ""

  },

  ...

    {

    "adcode": 420000,

    "name": "湖北省",

    "lng": "114.29857200",

    "lat": "30.58435500",

    "level": "province",

    "parent_adcode": ""

  },

  ...

]

```

然后如果需要获取湖北省所有的city, 返回格式为:


```json

[

  {

    "adcode": 420100,

    "name": "武汉市",

    "lng": "114.29857200",

    "lat": "30.58435500",

    "level": "city",

    "parent_adcode": "420000"

  },

  {

    "adcode": 420700,

    "name": "鄂州市",

    "lng": "114.89059300",

    "lat": "30.39653600",

    "level": "city",

    "parent_adcode": "420000"

  },

  {

    "adcode": 420800,

    "name": "荆门市",

    "lng": "112.20425100",

    "lat": "31.03542000",

    "level": "city",

    "parent_adcode": "420000"

  },

  ...

]

```

3.代码实现

{
    "pages": [
        "pages/index/index",
        "pages/style1/index",
        "pages/style2/index"
    ],
    "window": {
        "backgroundTextStyle": "light",
        "navigationBarBackgroundColor": "#fc8e5d",
        "navigationBarTitleText": "城市选择器",
        "navigationBarTextStyle": "black"
    },
    "tabBar": {
        "color": "#b3b3b3",
        "selectedColor": "#fc8e5d",
        "backgroundColor": "#f5f5f7",
        "borderStyle": "white",
        "list": [
            {
                "pagePath": "pages/index/index",
                "text": "城市选择",
                "iconPath": "images/1_4.png",
                "selectedIconPath": "images/1_5.png"
            },
            {
                "pagePath": "pages/index/index",
                "text": "占位图标",
                "iconPath": "images/1_2.png",
                "selectedIconPath": "images/1_3.png"
            }
        ]
    },
    "sitemapLocation": "sitemap.json"
}
/*
城市选择器
*/
//app.js
var hotapp = require('util/hotapp.js');
App({
  onLaunch: function () {
    //一行代码接入HotApp小程序统
    //统计接入成功后 会自动统计 今日启动数 昨日启动数 今日新增用户 昨日新增用户  今日活跃 昨日活跃数 今日累计用户
    hotapp.init("hotapp22259962");
  }
})
<!-- district.wxml -->
<template name="district">
    <block wx:if="{{districts.showProvinces}}">
        <scroll-view scroll-y="true"  class='district-section-wrap'>
            <view id="province" class='district-section'>
                <block wx:for="{{districts.provinces}}" >
                    <view class="district_name" data-adcode="{{item.adcode}}" data-name="{{item.name}}" bindtap="getCities">
                        {{item.name}}
                        <image class="district_arrow" src="../../images/1_7.png" ></image>
                    </view>
                </block>
            </view>
        </scroll-view >
    </block>
    <block wx:if="{{districts.showCities}}">
        <scroll-view scroll-y="true"  class='district-section-wrap' >
            <view id="city" class='district-section'>
                <block wx:for="{{districts.cities}}">
                    <view class="district_name" data-adcode="{{item.adcode}}" data-name="{{item.name}}" bindtap="getDistricts">
                        {{item.name}}
                        <image class="district_arrow" src="../../images/1_7.png" ></image>
                    </view>
                </block>
            </view>
        </scroll-view > 
    </block>
    <block wx:if="{{districts.showDistricts}}">
        <scroll-view scroll-y="true"  class='district-section-wrap' >
            <view id="town" class='district-section'>
                <block wx:for="{{districts.districts}}">
                    <view class="district_name" data-adcode="{{item.adcode}}" data-name="{{item.name}}" bindtap="finish">
                        {{item.name}}
                        <image class="district_arrow" src="../../images/1_7.png" ></image>
                    </view>
                </block>
            </view>
        </scroll-view >
    </block>
</template>
/*

*/
var host = 'https://sunjiaoshou/api/districts';
var districts = {
    provinces: [],
    cities: [],
    districts: [],
    showProvinces: false,
    showCities: false,
    showDistricts: false,
    selectedProvince: '',
    selectedCity: '',
    selectedDistrict: ''
};

//查询
function query(parent_adcode,cb){
    var adcode = '';

    //判断parent_adcode是不是function类型
    if((typeof parent_adcode == "function")){
        cb = parent_adcode;
    }else{
        adcode = parent_adcode;
    }

    wx.request({
        url: host, //仅为示例,并非真实的接口地址
        data: {
            parent_adcode: adcode 
        },
        header: {
            'content-type': 'application/json'
        },
        success: function(res) {
            typeof cb == "function" && cb(res.data)
        }
    })
}

/**
 * 获取省份
 */
function getProvinces(that) {
    query(function(data) {
        districts.provinces = data;
        if (data.length == 0) {
            getDistricts.showProvinces = false;
        } else {
            districts.showProvinces = true;
        }
        districts.showCities = false;
        districts.showDistricts = false;
        districts.selectedCity = '';
        districts.selectedDistrict = '';
        that.setData({
            districts: districts
        });
    });
}

/**
 * 获取城市
 */
function getCities(that, event) {
    var adcode = event.currentTarget.dataset.adcode;
    var provinceName = event.currentTarget.dataset.name;
    query(adcode, function(data) {
        districts.cities = data;
        districts.selectedProvince = provinceName;  
        districts.showProvinces = false;
        if (data.length == 0) {
            districts.showCities = false;
        } else {
            districts.showCities = true;
        }
        districts.selectedDistrict = '';
        districts.showDistricts = false;
        that.setData({
            districts: districts
        });
    });
}

/**
 * 获取地区
 */
function getDistricts(that, event) {
    var adcode = event.currentTarget.dataset.adcode;
    var cityName = event.currentTarget.dataset.name;
    query(adcode, function(data) {
        districts.districts = data;
        districts.selectedCity = cityName; 
        districts.showProvinces = false;
        districts.showCities = false;
        if (data.length == 0) {
            districts.showDistricts = false;
        } else {
            districts.showDistricts = true;
        }
        that.setData({
            districts: districts
        });
        console.log(that.data);
    });
}

/**
 * 选择完成
 */
function finish(that, event) {
    districts.showProvinces = false;
    districts.showCities = false;
    districts.showDistricts = false;
    districts.selectedDistrict = event.currentTarget.dataset.name;
    that.setData({
        districts: districts
    });
}

module.exports = {
  getProvinces: getProvinces,
  getCities: getCities,
  getDistricts: getDistricts,
  finish: finish
}

四、项目结构

五、代码下载

城市选择器小程序实现.zip

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/543740.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

4/11 QT_day5

服务器端 头文件 #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QTcpServer> #include <QMessageBox> #include <QTcpSocket> #include <QList> QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass …

Java应用CPU飙升和死锁排查实战教程

引言 在日常开发中&#xff0c;我们可能会遇到Java应用CPU飙升和死锁的问题。本文将通过实际案例&#xff0c;为大家介绍如何排查这些问题 Java应用CPU飙升和死锁排查步骤 先执行top命令&#xff0c;找到CPU占用比较高的进程再执行jstack 进程id > dump.txt找到进程中CPU…

[GDC24]TheFInals的破坏系统

GDC24上TheFinals的开发工作室–EmbarkStudios带来; TheFinals把实时破坏在主流游戏上提升到了新的高度,可以说是新的标杆,达成了: 可以出现大规模的任意破坏破坏之后充分影响gameplay,可以把建筑任意炸毁之后,坍塌的建筑继续保留&物理正确(有正确的网络同步),可以废墟中继…

2024HW --> 安全产品 Powershell无文件落地攻击

在HW中&#xff0c;除了了解中间件&#xff0c;web漏洞&#xff0c;这些攻击的手法&#xff0c;还得了解应急响应&#xff0c;安全产品&#xff0c;入侵排查&#xff0c;溯源反制...... 那么今天&#xff0c;就来说一下安全产品&#xff08;安全公司我就不说了&#xff0c;这个…

使用 ChatGPT-4 编码就像与一个醉酒的天才一起工作

我决定从头到尾使用 ChatGPT 来构建一个用于管理书签的 Chrome 扩展。在生成了 30,000 多行 JavaScript、HTML、CSS 和云后端后&#xff0c;我的收获是&#xff0c;使用 ChatGPT 进行编码就像与一个醉酒的编程天才一起工作&#xff1a;他很懒&#xff0c;患有记忆丧失&#xff…

二极管分类及用途

二极管分类及用途 通用开关二极管 特点&#xff1a;电流小&#xff0c;工作频率高 选型依据&#xff1a;正向电流、正向压降、功耗&#xff0c;反向最大电压&#xff0c;反向恢复时间&#xff0c;封装等 类型&#xff1a;BAS316 ; IN4148WS 应用电路: 说明&#xff1a;应用…

智能革命:未来人工智能创业的天地

智能革命&#xff1a;未来人工智能创业的天地 一、引言 在这个数字化迅速变革的时代&#xff0c;人工智能(AI)已经从一个边缘科学发展成为推动未来经济和社会发展的关键动力。这一技术领域的飞速进步&#xff0c;不仅影响着科技行业的每一个角落&#xff0c;更是为创业者提供了…

【python】python抓取古诗文内容保存(源码)【独一无二】

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

Ubuntu-22.04安装KVM虚拟机并安装Windows10

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、KVM是什么&#xff1f;二、安装步骤1.检查虚拟化2.查看KVM虚拟化3.安装KVM4.启用后台进程5.添加用户组6.重启电脑 三、使用步骤1.添加虚拟机2.配置虚拟机3.…

高颜值登录页面(一键复制)

你好&#xff0c;我是云桃桃。 一个希望帮助更多朋友快速入门 WEB 前端的程序媛。大专生&#xff0c;一枚程序媛&#xff0c;感谢关注。回复 “前端基础题”&#xff0c;可免费获得前端基础 100 题汇总&#xff0c;回复 “前端工具”&#xff0c;可获取 Web 开发工具合集 266篇…

leecode438 | 找到所有字符串中的异位词

题意大致是&#xff0c;给定两个字符串&#xff0c;s 和 p 其中 要在s 中找到由p的元素组成的子字符串&#xff0c;记录子字符串首地址 class Solution { public:vector<int> findAnagrams(string s, string p) {int m s.size(), n p.size();if(m < n)return {};vec…

python botos s3 aws

https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/s3.html AWS是亚马逊的云服务&#xff0c;其提供了非常丰富的套件&#xff0c;以及支持多种语言的SDK/API。本文针对其S3云储存服务的Python SDK&#xff08;boto3&#xff09;的使用进行介绍。 …

每日一题——阶乘计算升级版

题目链接&#xff1a; 6-10 阶乘计算升级版 - 基础编程题目集 (pintia.cn) 题目&#xff1a; 6-10 阶乘计算升级版 分数 20 本题要求实现一个打印非负整数阶乘的函数。 函数接口定义&#xff1a; void Print_Factorial ( const int N ); 其中N是用户传入的参数&#xff…

解锁智能未来:用Ollama开启你的本地AI之旅

Ollama是一个用于在本地运行大型语言模型&#xff08;LLM&#xff09;的开源框架。它旨在简化在Docker容器中部署LLM的过程&#xff0c;使得管理和运行这些模型变得更加容易。Ollama提供了类似OpenAI的API接口和聊天界面&#xff0c;可以非常方便地部署最新版本的GPT模型并通过…

商业银行业务与管理

商业银行业务与管理 资产负债表恒等式中国商业银行的资产负债表商业银行的业务种类银行运行管理的案例银行管理的基本准则流动性管理资产和负债管理资本充足管理 资产负债表恒等式 &#xff08;一般&#xff09;资产负债所有者权益 一个公司的资产是由负债和所有者权益所构成…

欧拉回路算法

1 基本概念 1.1 欧拉路径和欧拉回路 欧拉路径&#xff1a;欧拉路是指从图中任意一个点开始到图中任意一个点结束的路径&#xff0c;并且图中每条边通过的且只通过一次。 欧拉回路:欧拉回路是指起点和终点相同的欧拉路。 注意&#xff1a;如果欧拉回路&#xff0c;那么一定存在…

策略模式【行为模式C++】

1.概述 策略模式是一种行为设计模式&#xff0c; 它能让你定义一系列算法&#xff0c; 并将每种算法分别放入独立的类中&#xff0c; 以使算法的对象能够相互替换。 策略模式通常应用于需要多种算法进行操作的场景&#xff0c;如排序、搜索、数据压缩等。在这些情况下&#x…

【C++]C/C++的内存管理

这篇博客将会带着大家解决以下几个问题 1. C/C内存分布 2. C语言中动态内存管理方式 3. C中动态内存管理 4. operator new与operator delete函数 5. new和delete的实现原理 6. 定位new表达式(placement-new) 1. C/C内存分布 我们先来看下面的一段代码和相关问题 int global…

Unity 通过权重做随机

我们可以通过Random.Range方法结合权重来实现随机选择。具体步骤如下&#xff1a; 首先&#xff0c;创建一个数组&#xff0c;其中包含你要选择的项目&#xff0c;并为每个项目分配一个权重值。 计算所有权重值的总和。 使用Random.Range生成一个介于0和总权重之间的随机数。…

Hadoop+Spark大数据技术(微课版)曾国荪、曹洁版思维导图第四次作业 (第4章 HBase分布式DB)

1.简述Hbase的特点及与传统关系数据库的区别 HBase与传统关系数据库的区别 &#xff08;1&#xff09;数据类型 关系数据库具有丰富的数据类型&#xff0c;如字符串型、数值型、日期型、二进制型等。HBase只有字符串数据类型&#xff0c;数据的实际类型都是交由用户自己编写程序…