>위챗 애플릿 >미니 프로그램 개발 >소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개

소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개

巴扎黑
巴扎黑원래의
2017-09-12 09:28:271881검색

소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개렌더링:

소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개

소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개소스 코드

  • index.wxml

<import src="../../templates/address-temp"/>
<template is="addressPicker"
   data="{{provinceIndex:city.provinceIndex,cityIndex:city.cityIndex,districtIndex:city.districtIndex,province:city.province,
   city:city.city[city.selectedProvince],district:city.district[city.selectedCity]}}"/>
  • index.js

  var city = require("../../utils/city.js");
Page({
    data: {},
    onLoad: function() {
        console.log(&#39;onLoad...&#39;);
        var that = this;
        city.init(that);
    }
});
  • address-temp.wxml

<?xml version="1.0" encoding="utf-8"?>

<template name="addressPicker"> 
  <view style="display:flex;margin:0;height:100%;align-items: center;justify-content: center"> 
    <view style="width:100%;"> 
      <picker bindchange="bindProvinceChange" value="{{provinceIndex}}" range="{{province}}"> 
        <view style="text-align:center;padding:10rpx;font-size:0.8rem">{{province[provinceIndex]}}</view> 
      </picker> 
    </view>  
    <view style="width:100%;"> 
      <picker bindchange="bindCityChange" value="{{cityIndex}}" range="{{city}}"> 
        <view style="text-align:center;padding:10rpx;font-size:0.8rem">{{city[cityIndex]}}</view> 
      </picker> 
    </view>  
    <view style="width:100%;"> 
      <picker bindchange="bindDistrictChange" value="{{districtIndex}}" range="{{district}}"> 
        <view style="text-align:center;padding:10rpx;font-size:0.8rem">{{district[districtIndex]}}</view> 
      </picker> 
    </view> 
  </view>
</template>
  • city.js

var city = {
    province: [&#39;-请选择-&#39;, &#39;福建省&#39;],
    city: {
        &#39;-请选择-&#39;: [&#39;-请选择-&#39;],
        &#39;福建省&#39;: [&#39;福州市&#39;, &#39;厦门市&#39;, &#39;泉州市&#39;]
    },
    district: {
        &#39;-请选择-&#39;: [&#39;-请选择-&#39;],
        &#39;福州市&#39;: [&#39;鼓楼区&#39;, &#39;台江区&#39;],
        &#39;厦门市&#39;: [&#39;湖里区&#39;, &#39;集美区&#39;],
        &#39;泉州市&#39;: [&#39;晋江市&#39;, &#39;安溪县&#39;]
    },
    provinceIndex: 0,
    cityIndex: 0,
    districtIndex: 0,
    selectedProvince: &#39;-请选择-&#39;,
    selectedCity: &#39;-请选择-&#39;,
    selectedDistrct: &#39;-请选择-&#39;
};
function init(that) {
    that.setData({
        &#39;city&#39;: city
    });
    var bindProvinceChange = function(e) {
        var city = that.data.city;
        that.setData({
            &#39;city.provinceIndex&#39;: e.detail.value,
            &#39;city.selectedProvince&#39;: city.province[e.detail.value],
            &#39;city.selectedCity&#39;: city.city[city.province[e.detail.value]][0],
            &#39;city.selectedDistrct&#39;: city.district[city.city[city.province[e.detail.value]][0]][0],
            &#39;city.cityIndex&#39;: 0,
            &#39;city.districtIndex&#39;: 0
        });
    };
    var bindCityChange = function(e) {
        var city = that.data.city;
        that.setData({
            &#39;city.cityIndex&#39;: e.detail.value,
            &#39;city.selectedCity&#39;: city.city[city.selectedProvince][e.detail.value],
            &#39;city.districtIndex&#39;: 0,
            &#39;city.selectedDistrct&#39;: city.district[city.city[city.selectedProvince][e.detail.value]][0]
        });
    };
    var bindDistrictChange = function(e) {
        var city = that.data.city;
        that.setData({
            &#39;city.districtIndex&#39;: e.detail.value,
            &#39;city.selectedDistrct&#39;: city.district[city.selectedCity][e.detail.value]
        });
    };
    that[&#39;bindProvinceChange&#39;] = bindProvinceChange;
    that[&#39;bindCityChange&#39;] = bindCityChange;
    that[&#39;bindDistrictChange&#39;] = bindDistrictChange;
}
module.exports = {
    init: init
}

위 내용은 소규모 프로그램 구성 요소 개발에 있어 지방자치단체의 3단계 연계에 대한 관련 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.