在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美

當(dāng)前位置:雨林木風(fēng)下載站 > 應(yīng)用軟件教程 > 詳細(xì)頁(yè)面

微信小程序商城開(kāi)發(fā)之完成用戶收貨地址管理頁(yè)面的代碼

微信小程序商城開(kāi)發(fā)之完成用戶收貨地址管理頁(yè)面的代碼

更新時(shí)間:2025-09-24 文章作者:未知 信息來(lái)源:網(wǎng)絡(luò) 閱讀次數(shù):

導(dǎo)微信小程序,簡(jiǎn)稱(chēng)小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應(yīng)用,它實(shí)現(xiàn)了應(yīng)用“觸手可及”的夢(mèng)想,用戶掃一掃或搜一下即可打開(kāi)應(yīng)用。小程序是一種不用下載就能使用的應(yīng)用,也是一...
微信小程序,簡(jiǎn)稱(chēng)小程序,英文名Mini Program,是一種不需要下載安裝即可使用的應(yīng)用,它實(shí)現(xiàn)了應(yīng)用“觸手可及”的夢(mèng)想,用戶掃一掃或搜一下即可打開(kāi)應(yīng)用。小程序是一種不用下載就能使用的應(yīng)用,也是一項(xiàng)門(mén)檻非常高的創(chuàng)新,經(jīng)過(guò)將近兩年的發(fā)展,已經(jīng)構(gòu)造了新的小程序開(kāi)發(fā)環(huán)境和開(kāi)發(fā)者生態(tài)。
本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于微信小程序商城開(kāi)發(fā)之實(shí)現(xiàn)用戶收貨地址管理頁(yè)面的代碼 ,有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助。

看效果

微信小程序商城開(kāi)發(fā)之實(shí)現(xiàn)用戶收貨地址管理頁(yè)面的代碼

開(kāi)發(fā)計(jì)劃

1、布局收貨地址列表和新增收貨地址頁(yè)面

2、實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)功能

3、使用緩存管理數(shù)據(jù)

一、收貨地址列表管理

addressList.wxml

<scroll-view class="scroll" scroll-y="true">
  <view wx:for="{{addressList}}">
    <view class="product-name-wrap">
      <view class="ui-list-item-info">{{item.consignee}}
        <text decode="{{true}}" space="{{true}}">&nbsp;&nbsp;</text> {{item.mobile}}
      </view>
      <view class="ui-list-item-address">
        {{item.address}}
      </view>
      <view class="ui-list-item-time">
        <p>{{item.transportDay}}</p>
        <p class="ui-list-item-del" data-id="{{index}}" bindtap="delAddress">刪除</p>
      </view>
      <view class="separate"></view>
    </view>
  </view>
</scroll-view>
<view class="add-address" bindtap="addAddress">
  <image class="add-img"  src="../../images/add.png"></image>新增地址
</view>

addressList.wxss

page{  
  display: flex;  
  flex-direction: column;  
  height: 100%;  
}  
.product-name-wrap{
  margin: 0px 10px;
  font-size: 14px;
  color: #404040;
}
.ui-list-item-info{
  margin: 5px 0px;
}
.ui-list-item-address{
  color: #585c64;
}
.ui-list-item-time{
  margin: 5px 0px;
}
.ui-list-item-del{
  position: absolute;
  right: 10px;
  color: #585c64;
}
/* 分割線 */
.separate {
  margin: 5px 0px;
  height: 2rpx;
  background-color: #f2f2f2;
}
.add-address{
  margin: 0 auto;
  margin-top: 30px;
  width: 150px;
  height: 35px;
  border: 1px #000 solid;
  line-height: 35px;
  text-align: center;
  color: #000;
  border-radius: 5rpx;
      display: block;
}
.add-img{
  margin-right: 15rpx;
  width: 15px;
  height: 15px;
}

addressList.json

{
  "navigationBarTitleText": "管理地址"
}

addressList.js

Page({
 
  /**
   * 頁(yè)面的初始數(shù)據(jù)
   */
  data: {
    addressList:[]
  },
  /**
   * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載
   */
  onLoad: function (options) {
    var arr = wx.getStorageSync('addressList') || [];
    console.info("緩存數(shù)據(jù):" + arr);
    // 更新數(shù)據(jù)  
    this.setData({
      addressList: arr
    });
  },
 
  /**
   * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面顯示
   */
  onShow: function () {
    this.onLoad();
  },
  addAddress:function(){
    wx.navigateTo({ url: '../address/address' });
  },
  /* 刪除item */
  delAddress: function (e) {
    this.data.addressList.splice(e.target.id.substring(3), 1);
    // 更新data數(shù)據(jù)對(duì)象  
    if (this.data.addressList.length > 0) {
      this.setData({
        addressList: this.data.addressList
      })
      wx.setStorageSync('addressList', this.data.addressList);
    } else {
      this.setData({
        addressList: this.data.addressList
      })
      wx.setStorageSync('addressList', []);
    }
  }
})

二、新增收貨信息

address.wxml

<form bindsubmit="saveAddress">
  <view class="weui-cells weui-cells_after-title">
    <view class="weui-cell weui-cell_input">
      <view class="weui-cell__hd">
        <view class="weui-label">收貨人</view>
      </view>
      <view class="weui-cell__bd">
        <input class="weui-input" name="consignee" placeholder="請(qǐng)輸入收貨人真實(shí)姓名" />
      </view>
    </view>
    <view class="weui-cell weui-cell_input">
      <view class="weui-cell__hd">
        <view class="weui-label">手機(jī)號(hào)</view>
      </view>
      <view class="weui-cell__bd">
        <input class="weui-input" name="mobile" placeholder="請(qǐng)輸入收貨人手機(jī)號(hào)" />
      </view>
    </view>
    <view class="weui-cell weui-cell_select">
      <view class="weui-cell__hd weui-cell__hd_in-select-after">
        <view class="weui-label">收貨時(shí)間</view>
      </view>
      <view class="weui-cell__bd">
        <picker bindchange="bindTransportDayChange" value="{{transportIndex}}" range="{{transportValues}}">
          <view class="weui-select weui-select_in-select-after">{{transportValues[transportIndex]}}</view>
          <input name="transportDay" hidden="true" value="{{transportValues[transportIndex]}}" />
        </picker>
      </view>
    </view>
  </view>
  <view class="weui-cells__title"></view>
  <view class="weui-cells weui-cells_after-title">
    <view class="weui-cell weui-cell_select">
      <view class="weui-cell__hd weui-cell__hd_in-select-after">
        <view class="weui-label">省份</view>
      </view>
      <view class="weui-cell__bd">
        <picker bindchange="bindProvinceNameChange" value="{{provinceIndex}}" range="{{provinceNames}}">
          <view class="weui-select weui-select_in-select-after">{{provinceNames[provinceIndex]}}</view>
          <input name="provinceName" hidden="true" value="{{provinceNames[provinceIndex]}}" />
        </picker>
      </view>
    </view>
    <view class="weui-cell weui-cell_select">
      <view class="weui-cell__hd weui-cell__hd_in-select-after">
        <view class="weui-label">城市</view>
      </view>
      <view class="weui-cell__bd">
        <picker bindchange="bindCityNameChange" value="{{cityIndex}}"range="{{cityNames}}">
          <view class="weui-select weui-select_in-select-after"name="city_name">{{cityNames[cityIndex]}}</view>
 
          <input name="cityName" hidden="true" value="{{cityNames[cityIndex]}}" />
        </picker>
      </view>
    </view>
    <view class="weui-cell weui-cell_select">
      <view class="weui-cell__hd weui-cell__hd_in-select-after">
        <view class="weui-label">區(qū)縣</view>
      </view>
      <view class="weui-cell__bd">
        <picker bindchange="bindCountyNameChange" value="{{countyIndex}}"range="{{countyNames}}">
          <view class="weui-select weui-select_in-select-after">{{countyNames[countyIndex]}}</view>
          <input name="countyName" hidden="true" value="{{countyNames[countyIndex]}}" />
        </picker>
      </view>
    </view>
    <view class="weui-cell weui-cell_input">
      <view class="weui-cell__hd">
        <view class="weui-label">詳細(xì)地址</view>
      </view>
      <view class="weui-cell__bd">
        <input class="weui-input" name="address" placeholder="請(qǐng)輸入收貨人詳細(xì)地址" />
      </view>
    </view>
  </view>
  <button class="weui-btn" type="primary" form-type="submit">保存</button>
</form>

address.wxss

@import '../../utils/weui.wxss';
 
.weui-cells:before{
  top:0;
  border-top:1rpx solid white;
  }
.weui-cell{
  line-height: 3.5rem;
}
.weui-cells:after{
  bottom:0;border-bottom:1rpx solid white
}
 
.weui-btn{
  width: 80%;
}

address.json

{
  "navigationBarTitleText": "添加收貨地址"
}

address.js

var area = require('../../utils/area.js');
var areaInfo = []; //所有省市區(qū)縣數(shù)據(jù)
var provinces = []; //省
var provinceNames = []; //省名稱(chēng)
var citys = []; //城市
var cityNames = []; //城市名稱(chēng)
var countys = []; //區(qū)縣
var countyNames = []; //區(qū)縣名稱(chēng)
var value = [0, 0, 0]; //數(shù)據(jù)位置下標(biāo)
var addressList = null;
Page({
 
  /**
   * 頁(yè)面的初始數(shù)據(jù)
   */
  data: {
    transportValues: ["收貨時(shí)間不限", "周六日/節(jié)假日收貨", "周一至周五收貨"],
    transportIndex: 0,
    provinceIndex: 0, //省份
    cityIndex: 0, //城市
    countyIndex: 0, //區(qū)縣
  },
 
 
  /**
   * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載
   */
  onLoad: function(options) {
 
  },
 
  /**
   * 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面顯示
   */
  onShow: function() {
    var that = this;
    area.getAreaInfo(function(arr) {
      areaInfo = arr;
      //獲取省份數(shù)據(jù)
      that.getProvinceData();
    });
  },
  // 獲取省份數(shù)據(jù)
  getProvinceData: function() {
    var that = this;
    var s;
    provinces = [];
    provinceNames = [];
    var num = 0;
    for (var i = 0; i < areaInfo.length; i++) {
      s = areaInfo[i];
      if (s.di == "00" && s.xian == "00") {
        provinces[num] = s;
        provinceNames[num] = s.name;
        num++;
      }
    }
    that.setData({
      provinceNames: provinceNames
    })
 
    that.getCityArr();
    that.getCountyInfo();
  },
 
  // 獲取城市數(shù)據(jù)
  getCityArr: function(count = 0) {
    var c;
    citys = [];
    cityNames = [];
    var num = 0;
    for (var i = 0; i < areaInfo.length; i++) {
      c = areaInfo[i];
      if (c.xian == "00" && c.sheng == provinces[count].sheng && c.di != "00") {
        citys[num] = c;
        cityNames[num] = c.name;
        num++;
      }
    }
    if (citys.length == 0) {
      citys[0] = {
        name: ''
      };
      cityNames[0] = {
        name: ''
      };
    }
    var that = this;
    that.setData({
      citys: citys,
      cityNames: cityNames
    })
    console.log('cityNames:' + cityNames);
    that.getCountyInfo(count, 0);
  },
 
  // 獲取區(qū)縣數(shù)據(jù)
  getCountyInfo: function(column0 = 0, column1 = 0) {
    var c;
    countys = [];
    countyNames = [];
    var num = 0;
    for (var i = 0; i < areaInfo.length; i++) {
      c = areaInfo[i];
      if (c.xian != "00" && c.sheng == provinces[column0].sheng && c.di == citys[column1].di) {
        countys[num] = c;
        countyNames[num] = c.name;
        num++;
      }
    }
    if (countys.length == 0) {
      countys[0] = {
        name: ''
      };
      countyNames[0] = {
        name: ''
      };
    }
    console.log('countyNames:' + countyNames);
    var that = this;
    // value = [column0, column1, 0];
 
    that.setData({
      countys: countys,
      countyNames: countyNames,
      // value: value,
    })
  },
 
  bindTransportDayChange: function(e) {
    console.log('picker country 發(fā)生選擇改變,攜帶值為', e.detail.value);
    this.setData({
      transportIndex: e.detail.value
    })
  },
 
  bindProvinceNameChange: function(e) {
    var that = this;
    console.log('picker province 發(fā)生選擇改變,攜帶值為', e.detail.value);
    var val = e.detail.value
    that.getCityArr(val); //獲取地級(jí)市數(shù)據(jù)
    that.getCountyInfo(val, 0); //獲取區(qū)縣數(shù)據(jù)
 
    value = [val, 0, 0];
    this.setData({
      provinceIndex: e.detail.value,
      cityIndex: 0,
      countyIndex: 0,
      value: value
    })
 
  },
 
  bindCityNameChange: function(e) {
    var that = this;
    console.log('picker city 發(fā)生選擇改變,攜帶值為', e.detail.value);
 
    var val = e.detail.value
    that.getCountyInfo(value[0], val); //獲取區(qū)縣數(shù)據(jù)
    value = [value[0], val, 0];
    this.setData({
      cityIndex: e.detail.value,
      countyIndex: 0,
      value: value
    })
  },
 
  bindCountyNameChange: function(e) {
    var that = this;
    console.log('picker county 發(fā)生選擇改變,攜帶值為', e.detail.value);
    this.setData({
      countyIndex: e.detail.value
    })
  },
 
  saveAddress: function(e) {
    var consignee = e.detail.value.consignee;
    var mobile = e.detail.value.mobile;
    var transportDay = e.detail.value.transportDay;
    var provinceName = e.detail.value.provinceName;
    var cityName = e.detail.value.cityName;
    var countyName = e.detail.value.countyName;
    var address = e.detail.value.address;
 
    console.log(transportDay + "," + provinceName + "," + cityName + "," + countyName + "," + address); //輸出該文本 
 
    var arr = wx.getStorageSync('addressList') || [];
    console.log("arr,{}", arr);
    addressList = {
      consignee: consignee,
      mobile: mobile,
      address: provinceName + cityName + countyName+address,
      transportDay: transportDay
    }
      arr.push(addressList);
    wx.setStorageSync('addressList', arr);
    wx.navigateBack({
      
    })
  }
})

area.js和weui.wxss 可以看下方源碼獲取方式,這里就不多做解釋。

相關(guān)推薦:

微信小程序商城開(kāi)發(fā)之用微信授權(quán)并實(shí)現(xiàn)個(gè)人中心的頁(yè)面代碼

微信小程序商城開(kāi)發(fā)之實(shí)現(xiàn)商品加入購(gòu)物車(chē)的功能(代碼)

微信小程序商城開(kāi)發(fā)之https框架的搭建以及頂部和底部導(dǎo)航的實(shí)現(xiàn)

以上就是微信小程序商城開(kāi)發(fā)之實(shí)現(xiàn)用戶收貨地址管理頁(yè)面的代碼的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!


小程序是一種不需要下載安裝即可使用的應(yīng)用,它實(shí)現(xiàn)了應(yīng)用“觸手可及”的夢(mèng)想,用戶掃一掃或者搜一下即可打開(kāi)應(yīng)用。

溫馨提示:喜歡本站的話,請(qǐng)收藏一下本站!

本類(lèi)教程下載

系統(tǒng)下載排行

在线看毛片视频-国产免费av在线-欧美日韩一区二区三区-国产成人无码av在线播放无广告-亚洲人va欧美va人人爽-国产第一草草-西班牙黄色片-四虎在线网站8848-最新av片免费网站入口-东京热无码中文字幕av专区-日本大人吃奶视频xxxx-欧美精品一区二区三区四区五区-国产片天天弄-国产免费内射又粗又爽密桃视频-欧美爱爱网站-日韩v欧美
  • <li id="86scu"><menu id="86scu"></menu></li>
    <li id="86scu"></li>
    <button id="86scu"></button>
  • <s id="86scu"></s><button id="86scu"><menu id="86scu"></menu></button>
  • 国产精品va在线观看无码| 精品人妻一区二区三区四区在线 | 国产在线精品91| 无码精品国产一区二区三区免费| 两性午夜免费视频| 人妻少妇精品无码专区二区| 国产视频在线视频| 国产又黄又爽免费视频| www.亚洲视频.com| 人人干视频在线| 最新中文字幕免费视频| 国产尤物av一区二区三区| 99久久激情视频| 成人小视频在线看| av动漫在线播放| 日本a在线天堂| 免费观看亚洲视频| 一级片免费在线观看视频| 成人免费观看毛片| 精品国产无码在线| 欧美黄色一级片视频| 波多野结衣家庭教师视频| 欧美精品久久久久久久免费| 欧美激情第3页| 国产999免费视频| 国内国产精品天干天干| 黄大色黄女片18第一次| 毛片一区二区三区四区| 亚洲免费黄色录像| 丰满少妇久久久| 最新天堂在线视频| 国产乱人伦精品一区二区三区| 国产精品网站免费| 手机版av在线| 777av视频| 黄色录像特级片| 三级4级全黄60分钟| 伊人国产精品视频| 毛片在线视频观看| av观看免费在线| 小明看看成人免费视频| 男女私大尺度视频| 丰满女人性猛交| 欧美午夜小视频| 国产5g成人5g天天爽| 国产黄页在线观看| 污视频在线观看免费网站| 黑人糟蹋人妻hd中文字幕| 日本精品一区在线| 女人喷潮完整视频| 久久最新免费视频| 国产性生交xxxxx免费| 黄色网zhan| 欧美男女交配视频| 国产一区二区四区| 北条麻妃在线一区| 男女视频网站在线观看| 妞干网视频在线观看| 国产精品人人妻人人爽人人牛| 免费看日本黄色| 丰满爆乳一区二区三区| 日本一二三四区视频| 孩娇小videos精品| 国产毛片久久久久久国产毛片| 欧美大片久久久| 久久久精品三级| 在线观看免费污视频| 国产免费xxx| 国产精品久久..4399| 久久久久久久片| 免费av不卡在线| 一二三在线视频| 欧美 日韩 国产在线观看| 亚洲五月天综合| 国产成人无码av在线播放dvd| 美女日批免费视频| 免费国产成人av| chinese少妇国语对白| 手机av在线网| 在线观看日本www| 天天操狠狠操夜夜操| 精品国产av无码一区二区三区| 欧美日韩黄色一级片| www插插插无码视频网站| 99久久国产综合精品五月天喷水| 中文字幕第22页| 黄色免费高清视频| 国产欧美日韩小视频| 免费成人午夜视频| 可以免费观看av毛片| 一级黄色片播放| 92看片淫黄大片一级| 精品国产一区二区三区无码| 亚洲国产精品女人| 成年丰满熟妇午夜免费视频| 福利视频免费在线观看| 日韩av片在线看| 国产福利在线免费| 免费观看中文字幕| 日本精品久久久久久久久久| 无码精品国产一区二区三区免费| 麻豆三级在线观看| 水蜜桃在线免费观看| 成年人视频在线免费| 午夜一区二区视频| 日韩成人手机在线| www.com黄色片| 国产在线视频综合| 亚洲免费看av| 免费看毛片的网址| 成人亚洲免费视频| 日本www在线视频| 五月天激情图片| 成人性生生活性生交12| 高清无码一区二区在线观看吞精| 国内外成人免费激情视频| 国产极品尤物在线| 91大学生片黄在线观看| 老司机av福利| 91黄色在线看| 妞干网视频在线观看| 国产又爽又黄ai换脸| 免费在线激情视频| 天天想你在线观看完整版电影免费| 亚洲va在线va天堂va偷拍| 日本一二区免费| 色多多视频在线播放| 免费日韩中文字幕| 国产91对白刺激露脸在线观看| 日韩精品一区二区免费| 在线观看成人免费| 国产高清av片| www.久久久久久久久久久| 91极品视频在线观看| 欧美丰满熟妇xxxxx| 国产成年人在线观看| 成人在线播放网址| 91国内在线播放| 91香蕉视频在线观看视频| 狠狠干狠狠操视频| 黄色一级片免费播放| 天天爱天天做天天操| 久久久久亚洲av无码专区喷水| 中国一级黄色录像| www.夜夜爱| 国产午夜伦鲁鲁| 日本黄色三级大片| 嫩草影院国产精品| 五月六月丁香婷婷| 妞干网这里只有精品| www婷婷av久久久影片| 国产精品视频一二三四区| 国产精品久久久久9999爆乳| 777777av| 成人在线观看黄| 欧美在线a视频| 97超碰国产精品| 蜜臀av午夜一区二区三区 | 日韩国产成人无码av毛片| 久久久久免费看黄a片app| av动漫免费看| www.久久久久久久久久久| 日本黄xxxxxxxxx100| 99爱视频在线| 久久久国产欧美| www.成人黄色| 国产 日韩 欧美在线| 成人黄色一区二区| 日本一本在线视频| 青青草成人免费在线视频| 成年人在线看片| 最新av在线免费观看| 免费毛片网站在线观看| 天堂…中文在线最新版在线| 国产第一页视频| www.偷拍.com| 欧美亚洲一二三区| 深爱五月综合网| 激情综合在线观看| 亚洲综合20p| 欧美精品色婷婷五月综合| 国产高清免费在线| 欧美一级黄色片视频| www婷婷av久久久影片| 日本久久久久久久久久久久| 国产成人亚洲综合无码| 视频在线观看免费高清| 日韩 欧美 视频| 91亚洲一区二区| 黄色一级免费大片| 国产精品va在线观看无码| 小明看看成人免费视频| 中国丰满人妻videoshd| 天堂av在线中文| 污网站免费在线| 日本三级免费观看| 国产欧美日韩小视频| 三级黄色片免费观看| 国产高潮免费视频| 亚洲 高清 成人 动漫|