微信小程序收获地址管理

收获地址这部分主要有四个功能:新增地址,修改地址,删除地址,选择地址。

其中修改,删除,新增可以放在一个界面中,话不多说上代码

界面

image

选择界面

<view class='container'>
  <view class = "item" wx:for="{{list}}" wx:key="" wx:for-index="index" data-address='{{item.address}}{{item.door_card}}' data-name='{{item.name}}' data-phone='{{item.phone}}' data-id='{{item.address_id}}' bindtap='select'>
    <text class='address'>{{item.address}}{{item.door_card}}</text>
    <text class='name' >{{item.name}}</text>
    <text class='tel'>{{item.phone}}</text>
    <image class='eidt' src = "../../../images/icon/modify.png" mode = "widthFix" data-index='{{index}}' bindtap = "edit"/>
  </view>
</view>
<view class = "add" bindtap = "addAddre">
  <image  class = "left" src = "../../../images/icon/add.png" mode = "widthFix" />
  <view class = "text">新增个人地址</view>
  <image class="right" src = "../../../images/icon/right.png" mode = "widthFix" />
</view>

选择界面逻辑

新增地址点击,编辑按钮点击,选择地址后为上一页面的地址栏赋值;注意数据刷新一般放在onShow中

// pages/me/address/address.js
const tools = require('../../../utils/tools.js');
var app = getApp();
Page({
  data: {
    list:[]
  },
  onLoad: function (options) {
  },
  //修改地址
  edit: function (e){
    console.log(this.data.list[e.currentTarget.dataset.index])
    var address = this.data.list[e.currentTarget.dataset.index]
    wx.navigateTo({
    url: '/pages/me/address/add-address/add-address?address='+ JSON.stringify(address)
   })
  },
  //显示地址列表
  onShow: function (options){
    var vm = this;
    tools.request(app.globalData.url + "/info/Address", 'post', {})
      .then(resp => {
        console.log("收到服务器回复地址信息", resp.data.data)
        vm.setData({
          list: resp.data.data
        })
      })
  },
  //增加地址
  addAddre: function () {
    wx.navigateTo({
      url: '/pages/me/address/add-address/add-address'
    })
  },
  //选择地址
  select: function(e){
    //为上一个页面的data赋值
    var pages = getCurrentPages(); // 获取页面栈
    var currPage = pages[pages.length - 1]; // 当前页面
    var prevPage = pages[pages.length - 2]; // 上一个页面
    if (prevPage.__route__ == 'pages/shoppingcart/pay/pay') {
      var address = {
        name: e.currentTarget.dataset.name,
        address: e.currentTarget.dataset.address,
        phone: e.currentTarget.dataset.phone,
        id: e.currentTarget.dataset.id
      }
      console.log("为上一个页面的address赋值",address)
      prevPage.setData({
        address: address
      })
      wx.navigateBack({
        delta: 1
      })
   }
  }
})

新增/修改地址界面

image
<!--pages/me/address/add-address/add-address.wxml-->
<!-- 信息部分 --> 
<form bindsubmit="saveAddr" report-submit="true">
<view class = "info">
<!-- 姓名部分 -->
<view class = "item">
<text>姓名</text>
<view class = "right">
<input type="text" name = "name" placeholder="请填写收货人姓名"  value="{{list.name}}" />
</view>
</view>

<!-- 电话部分 -->
<view class = "item">
<text>电话</text>
<view class = "right">
<input name="phone" type="number" placeholder="请填写收货手机号"  value="{{list.phone}}"/>
</view>
</view>

<!-- 收货地址部分 -->
<view class = "item">
<text>地址</text>
<view class = "right1" bindtap='cilickaddress'>
  <text class='t1' wx:if="{{!address}}">点击选择</text>
  <input name="address"  wx:else value="{{address}}" />
  <image src='../../../../images/icon/right.png'></image>
</view>
</view>

<!-- 详细地址部分 -->
<view class = "item">
<text>详细地址</text>
<view class = "right">
<input name="door_card" type="text" placeholder="例: 10栋5层502室"  value="{{list.door_card}}" />
</view>
</view>

</view>
<!-- 信息部分end -->
    
<view class='save'>
  <button class="savebt" formType="submit" hover-class="none">保存</button>
</view>
<view class="delete" bindtap='delete' hidden='{{tag}}'>删除</view>
</form>

js逻辑

地址部分使用了定位功能,详情请看<a href='https://blog.csdn.net/qq_42002651/article/details/89384456'> 微信小程序中腾讯位置API使用</a> ,通过判断传入值来决定是否显示删除按钮。

// pages/me/address/add-address/add-address.js
const tools = require('../../../../utils/tools.js');
var app = getApp();
Page({
  data: {
    tag: true
  },
    //判断是否有传入值
  onLoad: function (e) {
    console.log(e.address)
    if (e.address != undefined){
      var list = JSON.parse(e.address);
      this.setData({
        list: list,
        address: list.address,
        address_id: list.address_id
      })
    }else{
      console.log("不存在传入值")
    }
  },
  onShow: function(e){
    if (this.data.list != undefined){
      console.log("存在传入值")
      this.setData({
        tag:false
      })
    }
  },
  //点击地址信息,定位
  cilickaddress: function(e){
    wx.navigateTo({
      url: '/pages/home/address/address',
    })
  },
  //保存修改地址
  saveAddr: function(e){
    if (e.detail.value.name == "") {
      wx.showModal({
        title: '提示',
        content: "请填写您的姓名!"
      })
    } else if (e.detail.value.phone == "") {
      wx.showModal({
        title: '提示',
        content: "请填写您的手机号!"
      })
    } else if (!(/^1(3|4|5|7|8)\d{9}$/.test(e.detail.value.phone))) {
      wx.showModal({
        title: '提示',
        content: "手机号格式不正确"
      })
    } else if (e.detail.value.address === undefined) {
      wx.showModal({
        title: '提示',
        content: "请选择您的所在区域"
      })
    } else if (e.detail.value.door_card == "") {
      wx.showModal({
        title: '提示',
        content: "请输入您的详细地址"
      })
    }else {
      console.log(e.detail.value);
      if(this.data.tag === true){
        var address = e.detail.value
        address = JSON.stringify(address);
        //保存新地址
        tools.request(app.globalData.url + "/info/InsertAddress", 'post', {'address': address})
          .then(resp => {
            console.log("新增地址成功", resp)
            wx.showToast({
              title: resp.data.msg,
              icon: 'success',
              duration: 1500,
              success: function () {
                setTimeout(function () {
                  wx.navigateBack({
                    delta: 1
                  })
                }, 1500);
              }
            })
          })
      }else{
        var address = e.detail.value
        address.address_id = this.data.address_id;
        address = JSON.stringify(address);
        //修改地址
        tools.request(app.globalData.url + "/info/AlterAddress", 'post', { 'address': address })
          .then(resp => {
            console.log("修改地址成功", resp)
            wx.showToast({
              title: resp.data.msg,
              icon: 'success',
              duration: 1500,
              success: function () {
                setTimeout(function () {
                  wx.navigateBack({
                    delta: 1
                  })
                }, 1500);
              }
            })
          })
      }
    }
  },
  //删除该地址
  delete: function(e){
    var vm = this;
    console.log(vm.data.address_id)
    tools.request(app.globalData.url + "/info/DeleteAddress", 'post', { 'address_id': vm.data.address_id})
      .then(resp => {
        console.log("删除地址成功", resp)
        wx.showToast({
          title: resp.data.msg,
          icon: 'success',
          duration: 1500,
          success: function () {
            setTimeout(function () {
              wx.navigateBack({
                delta: 1
              })
            }, 1500);
          }
        })
      })
  }
})
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容

  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,350评论 0 17
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,082评论 1 32
  • 我有个朋友,爱裸睡,常常失眠,在家喜欢光着身子在黑夜里吸烟。 他跟我住同一层宿舍楼,在学校当然不能裸奔,就经常看到...
    明火白粥阅读 1,623评论 16 24
  • 首先请原谅我这流水账似的心情记录。 我们一起度过国外孤单的四年,一起疯耍,一起学习,一起挑灯熬夜备考。如今都只能是...
    一枚奋斗的胖子阅读 607评论 0 1