微信小程式商城開發之實現用戶收貨地址管理頁面的程式碼
這篇文章帶給大家的內容是關於微信小程式商城開發之實現用戶收貨地址管理頁面的程式碼,有一定的參考價值,有需要的朋友可以參考一下,希望對你有所幫助。
看效果
#開發計畫
1 、佈局收貨地址清單和新增收貨地址頁面
2、實現省市縣三級連動功能
3、使用快取管理資料
一、收貨地址清單管理
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}}"> </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({ /** * 页面的初始数据 */ data: { addressList:[] }, /** * 生命周期函数--监听页面加载 */ onLoad: function (options) { var arr = wx.getStorageSync('addressList') || []; console.info("缓存数据:" + arr); // 更新数据 this.setData({ addressList: arr }); }, /** * 生命周期函数--监听页面显示 */ 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数据对象 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="请输入收货人真实姓名" /> </view> </view> <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="mobile" placeholder="请输入收货人手机号" /> </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="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">区县</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">详细地址</view> </view> <view class="weui-cell__bd"> <input class="weui-input" name="address" placeholder="请输入收货人详细地址" /> </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 = []; //所有省市区县数据 var provinces = []; //省 var provinceNames = []; //省名称 var citys = []; //城市 var cityNames = []; //城市名称 var countys = []; //区县 var countyNames = []; //区县名称 var value = [0, 0, 0]; //数据位置下标 var addressList = null; Page({ /** * 页面的初始数据 */ data: { transportValues: ["收货时间不限", "周六日/节假日收货", "周一至周五收货"], transportIndex: 0, provinceIndex: 0, //省份 cityIndex: 0, //城市 countyIndex: 0, //区县 }, /** * 生命周期函数--监听页面加载 */ onLoad: function(options) { }, /** * 生命周期函数--监听页面显示 */ onShow: function() { var that = this; area.getAreaInfo(function(arr) { areaInfo = arr; //获取省份数据 that.getProvinceData(); }); }, // 获取省份数据 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(); }, // 获取城市数据 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); }, // 获取区县数据 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 发生选择改变,携带值为', e.detail.value); this.setData({ transportIndex: e.detail.value }) }, bindProvinceNameChange: function(e) { var that = this; console.log('picker province 发生选择改变,携带值为', e.detail.value); var val = e.detail.value that.getCityArr(val); //获取地级市数据 that.getCountyInfo(val, 0); //获取区县数据 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 发生选择改变,携带值为', e.detail.value); var val = e.detail.value that.getCountyInfo(value[0], val); //获取区县数据 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 发生选择改变,携带值为', 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 可以看下方原始碼取得方式,這裡就不多做解釋。
相關推薦:
微信小程式商城開發之https框架的搭建以及頂部和底部導航的實現
以上是微信小程式商城開發之實現用戶收貨地址管理頁面的程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

閒魚官方微信小程式悄悄上線,在小程式中可以發布閒置與買家/賣家私訊交流、查看個人資料及訂單、搜尋物品等,有用好奇閒魚微信小程式叫什麼,現在快來看一下。閒魚微信小程式叫什麼答案:閒魚,閒置交易二手買賣估價回收。 1、在小程式中可以發布閒置、與買家/賣家私訊交流、查看個人資料及訂單、搜尋指定物品等功能;2、在小程式的頁面中有首頁、附近、發閒置、訊息、我的5項功能;3、想要使用的話必要要開通微信支付才可以購買;

實現微信小程式中的圖片濾鏡效果隨著社群媒體應用程式的流行,人們越來越喜歡在照片中應用濾鏡效果,以增強照片的藝術效果和吸引力。在微信小程式中也可以實現圖片濾鏡效果,為使用者提供更多有趣和創意的照片編輯功能。本文將介紹如何在微信小程式中實現圖片濾鏡效果,並提供具體的程式碼範例。首先,我們需要在微信小程式中使用canvas元件來載入和編輯圖片。 canvas元件可以在頁面

實現微信小程式中的下拉式選單效果,需要具體程式碼範例隨著行動互聯網的普及,微信小程式成為了網路開發的重要一環,越來越多的人開始關注和使用微信小程式。微信小程式的開發相比傳統的APP開發更加簡單快捷,但也需要掌握一定的開發技巧。在微信小程式的開發中,下拉式選單是一個常見的UI元件,實現了更好的使用者操作體驗。本文將詳細介紹如何在微信小程式中實現下拉式選單效果,並提供具

閒魚官方微信小程式已經悄悄上線,它為用戶提供了一個便捷的平台,讓你可以輕鬆地發布和交易閒置物品。在小程式中,你可以與買家或賣家進行私訊交流,查看個人資料和訂單,以及搜尋你想要的物品。那麼閒魚在微信小程式中究竟叫什麼呢,這篇教學攻略將為您詳細介紹,想要了解的用戶們快來跟著本文繼續閱讀吧!閒魚微信小程式叫什麼答案:閒魚,閒置交易二手買賣估價回收。 1、在小程式中可以發布閒置、與買家/賣家私訊交流、查看個人資料及訂單、搜尋指定物品等功能;2、在小程式的頁面中有首頁、附近、發閒置、訊息、我的5項功能;3、

微信小程式實現圖片上傳功能隨著行動網路的發展,微信小程式已經成為了人們生活中不可或缺的一部分。微信小程式不僅提供了豐富的應用場景,還支援開發者自訂功能,其中包括圖片上傳功能。本文將介紹如何在微信小程式中實作圖片上傳功能,並提供具體的程式碼範例。一、前期準備工作在開始編寫程式碼之前,我們需要先下載並安裝微信開發者工具,並註冊成為微信開發者。同時,也需要了解微信

使用微信小程式實現輪播圖切換效果微信小程式是一種輕量級的應用程序,具有簡單、高效的開發和使用特點。在微信小程式中,實作輪播圖切換效果是常見的需求。本文將介紹如何使用微信小程式實現輪播圖切換效果,並給出具體的程式碼範例。首先,在微信小程式的頁面檔案中,新增一個輪播圖元件。例如,可以使用<swiper>標籤來實現輪播圖的切換效果。在該組件中,可以透過b

實現微信小程式中的圖片旋轉效果,需要具體程式碼範例微信小程式是一種輕量級的應用程序,為用戶提供了豐富的功能和良好的用戶體驗。在小程式中,開發者可以利用各種元件和API來實現各種效果。其中,圖片旋轉效果是一種常見的動畫效果,可以為小程式增添趣味性和視覺效果。在微信小程式中實作圖片旋轉效果,需要使用小程式提供的動畫API。以下是一個具體的程式碼範例,展示如何在小程

實作微信小程式中的滑動刪除功能,需要具體程式碼範例隨著微信小程式的流行,開發者在開發過程中經常會遇到一些常見功能的實作問題。其中,滑動刪除功能是常見、常用的功能需求。本文將為大家詳細介紹如何在微信小程式中實現滑動刪除功能,並給出具體的程式碼範例。一、需求分析在微信小程式中,滑動刪除功能的實作涉及以下要點:列表展示:要顯示可滑動刪除的列表,每個列表項目需要包
