欢迎光临
我们一直在努力

微信小程序城市选择器如何实现

这篇文章主要讲解了“微信小程序城市选择器如何实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“微信小程序城市选择器如何实现”吧!

城市选择器 region

//index.wxml<picker mode="region" bindchange="bindRegionChange" value="{{region}}">
  <view class="picker">当前选择:{{region[0]}},{{region[1]}},{{region[2]}}
  view>picker>

//index.js
data: {
    region: ['广东省', '广州市', '海珠区']
}

多列选择器 multiSelector

// City.js

//  省份
var provinceList = [
  { "id": "11", "name": "北京", "initial": "B" },  ...];

var cityList = [
  {"provinceId": "11","citys": [
      { "id": "1", "name": "昌平" },     ...]
  }
];
//  点击省份,获取城市列表function getCitysById(id) {
  let provinceId = provinceList[id].id;
  var tempObj = [];  for (let i = 0; i < cityList.length; i++) {if (cityList[i].provinceId == provinceId) {
      tempObj = cityList[i].citys;      break;
    }
  }  return tempObj;
}

module.exports = {
  provinceList: provinceList,
  getCitysById: getCitysById
}

// Picker.wxml

<picker mode="multiSelector" value="{{index}}" bindcolumnchange="bindPickerChange" range="{{province}}" range-key="{{'name'}}">
  <view class="picker">当前选择:{{province[0][0].name}}{{province[1][0].name}}
  view>picker>

// Picker.js

// picker.jsvar cityObj = require("../../utils/city")
Page({
  data: {
    index: 0
  },
  onLoad: function (options) {var defaultCitys = cityObj.getCitysById("0")this.setData({
      province: [cityObj.provinceList, defaultCitys]
    })
  },
  bindPickerChange(e) {if (e.detail.column == 0) {      var citys = cityObj.getCitysById(e.detail.value);      this.setData({
        province: [cityObj.provinceList, citys]
      })
    }
  }
})

时间选择器 time

<picker mode="time" value="{{time}}" start="09:01" end="21:01" bindchange="bindTimeChange">
  <view class="picker">当前选择: {{time}}
  view>picker>

日期选择器 date

<picker mode="date" value="{{time}}" start="2015-09-01" end="2017-09-01" fields="month" bindchange="bindTimeChange">
  <view class="picker">当前选择: {{time}}
  view>picker>

rich-text

  • 属性:nodes 类型:Array / String 结点列表 / HTML String

  • 全局支持class和style属性,不支持id属性。

  • 结点类型:type = node  name 标签名 String 是 支持部分受信任的HTML结点  attrs 属性 Object 否 支持部分受信任的属性,遵循Pascal命名法  children 子结点列表 Array 否 结构和nodes一致

  • 结点类型:type = text  text 文本 String 是 支持entities

  • nodes 不推荐使用 String 类型,性能会有所下降

  • rich-text 组件内屏蔽所有结点的事件。

  • attrs 属性不支持 id ,支持 class 。

  • name 属性大小写不敏感。

  • 如果使用了不受信任的HTML结点,该结点及其所有子结点将会被移除。

  • img 标签仅支持网络图片。

<rich-text nodes="{{nodes}}" /><rich-text nodes="{{nodes1}}" /><rich-text nodes="{{nodes2}}" />

this.setData({
    nodes: "

html标题

", nodes1: [{ name: "h2", attrs: { style: "color:red", class: "red" }, children: [{ type: "text", text: '结点列表标题' }] }], nodes2: [{ name: "ul", attrs: { style: "padding:20px;border:1px solid blue;", class: "red" }, children: [ { name: "li", attrs: { style: "color:red", class: "red" }, children: [{ type: "text", text: '多层结点 无序列表' }], }, { name: "li", attrs: { style: "color:red", class: "red" }, children: [{ type: "text", text: '多层结点 无序列表1' }], }] }] })

.appreciate{ margin-bottom:16px;}
.appreciate .btn_appreciation { display: block; width: 110px; height: 40px; margin: 40px auto 0;font-size: 18px; line-height: 40px; text-align: center; vertical-align: middle; color: #fff; border-radius: 5px; background: #ff8000;}
.appreciate .head_count.show { display: block;}
.appreciate .head_count {display: none; margin: 30px auto 0; font-size: 14px;text-align: center;}
.appreciate .head_count i {color: #ff8000;}
.appreciate .head_count b {color: gray;}
.appreciate_list_wrapper{ overflow: hidden; margin: 0 auto; width: 200px;}
.appreciate_list.vcenter{ text-align: center;}
.appreciate_list.vcenter a{ display:block;}
.appreciate_list { max-height: 120px; overflow: hidden; margin-right: -6px; line-height: 15px;}
.appreciate_list img { position: relative; width: 34px; height: 34px; margin: 0 6px 4px 0; border-radius: 17px;max-width: 100%!important;}
.appreciate .btn_appreciation_t{background: #dc5d4a;}
.appreciate .head_count_t i {color: #607fa6;}
.appreciate_list_wrapper_t{ overflow: hidden; margin: 0 auto; width: 250px;}
.appreciate_list_t.vcenter_t { text-align: center;}
.appreciate_list_t.vcenter_t a{ display:block;}
.appreciate_list_t { max-height: 120px; overflow: hidden; margin-right: -6px; line-height: 15px;}
.appreciate_list_t img { position: relative; width: 30px; height: 30px; margin: 0 6px 4px 0;max-width: 100%!important;}

感谢各位的阅读,以上就是“微信小程序城市选择器如何实现”的内容了,经过本文的学习后,相信大家对微信小程序城市选择器如何实现这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是云搜网,小编将为大家推送更多相关知识点的文章,欢迎关注!

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。