地址模块实现

地址页面:


image.png

1、地址列表渲染

首先在这个页面中请求用户的地址列表数据,请求后在前端进行渲染。
前端代码:

 mounted(){
        this.init();
      },
 methods:{
        init(){
          axios.get('users/addressList').then((response)=>{
            let res=response.data;
            this.addressList=res.result;
            this.selectedAddrId=this.addressList[0].addressId;
          })
          // console.log(this)
          //为什么在这打不出addressList?????因为异步
          // console.log(this.addressList)      
        },

后端代码:

router.get('/addressList',(req,res,next)=>{
    let userId=req.cookies.userId;
    User.findOne({userId:userId},(err,doc)=>{
        if(err){
            res.json({
                status:'1',
                msg:err.message,
                result:''
            })
        }else{
            res.json({
                status:'0',
                msg:'',
                result:doc.addressList
            })
        }
    })
})

在页面渲染时,有一个功能需要实现,默认显示三个地址,点击more展现所有地址列表,点击收回。这就要在li标签中的v-for=“item in addressList”将adderList改变为addressListFilter,然后在computed中注册该数据并实时监听改变.limit初始值为3,点击loadMore时将limit设为列表长度。

 computed:{
        addressListFilter(){
          return this.addressList.slice(0,this.limit);
        }
      },

列表切换功能在li标签上点击将这个index复制给checkIndex,而且在li标签上用class=‘open’来控制选中状态。

<li v-for="(item,index) in addressListFilter" :class="{'check':checkIndex==index}" @click="checkIndex=index; selectedAddrId=item.addressId">

2、设置默认功能实现

<div class="addr-opration addr-set-default">
        <a href="javascript:;" class="addr-set-default-btn" v-if="!item.isDefault" @click="setDefault(item.addressId)"><i>Set default</i></a>
 </div>
<div class="addr-opration addr-default" v-if="item.isDefault">Default address</div>

通过 v-if="item.isDefault"和v-if="!item.isDefault"来控制默认地址和设置默认的显示,如果点击设置默认,将这个item的addressId传给setDefault参数。返回结果后遍历列表,将如果等于传进来的addressId就将isDefault设置为true,反之为false,来控制地址列表中的显示。

setDefault(addressId){    
          axios.post('/users/setDefault',{
            addressId:addressId
          }).then((response)=>{
              this.addressList.forEach((item)=>{
                if(item.addressId==addressId){
                  item.isDefault=true;
                }else{
                  item.isDefault=false;
                }
              })
          })
        },

在后台也需要将isDefault的值进行同步。注意一点,在找到addressId并更改其isDefault后,要将这个item变成这个列表数组的第一个值,这样下次进来这个页面他就在第一个显示了。

router.post('/setDefault',(req,res,next)=>{
    let userId=req.cookies.userId;
    let addressId=req.body.addressId;
    User.findOne({userId:userId},(err,doc)=>{
        if(err){
            res.json({
                status:'1',
                msg:err.message,
                result:''
            })
        }else{
            doc.addressList.forEach((item,index)=>{
                if(item.addressId==addressId){
                    item.isDefault=true;
                    doc.addressList.splice(index,1);
                    doc.addressList.unshift(item);
                }else{
                     item.isDefault=false;
                }
            })

            doc.save((err1,doc1)=>{
                if(err){
                    res.json({
                        status:'1',
                        msg:err.message,
                        result:''
                    })
                }else{
                    res.json({
                        status:'0',
                        msg:'',
                        result:''
                    })
                }
            })
        }
    })
})

3、删除功能实现

点击删除图标后,将此地址的addressId传给delAdress函数。delAdress函数中将addreId传给data中定义的变量addressId,并将确认删除的模态框弹出来。点击模态框的确认删除按钮后,将调用delConfirm函数,在这个函数中向后台发出post请求,传递addressId这个参数,以便后台查找数据,删除后将模态框关闭,并重新渲染页面。

<a href="javascript:;" class="addr-del-btn" @click="delAdress(item.addressId)">
       delAdress(addressId){
          this.addressId=addressId;
          this.mdDel=true;
        },
        delConfirm(){
          axios.post('/users/delAdress',{
            addressId:this.addressId
          }).then((response)=>{
            let res=response.data;
            this.mdDel=false;
            this.init();
          })

        }
      },

后台删除数据:
通过update和$pull来删除数据。

router.post('/delAdress',(req,res,next)=>{
    let userId=req.cookies.userId;
    let addressId=req.body.addressId;
    User.update({userId:userId},{$pull:{'addressList':{'addressId':addressId}}},(err,doc)=>{
        if(err){
            res.json({
                status:'1',
                msg:err.message,
                result:''
            })
        }else{
            res.json({
                status:'0',
                msg:'删除成功',
                result:'suc'
            })
        }
    })
})

4、点击next给下一个页面传递选中的addressId的参数,直接传到url中。

 <router-link class="btn btn--m btn--red" :to="{path:'orderConfirm',query:{'addressId':selectedAddrId}}">Next</router-link>

这个selectedAddrId默认值是列表第一个的id,点击后,将其改变

<li v-for="(item,index) in addressListFilter" :class="{'check':checkIndex==index}" @click="checkIndex=index; selectedAddrId=item.addressId">
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,570评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,100评论 18 139
  • 过去的就是过去, 再美好也回不来 再纠结也是死局 而现在的就是现在 陌上花发 温柔以待 缓缓彳亍 便足矣 太多的匆...
    今兮何兮阅读 69评论 0 0
  • 大学毕业的时候,我特别的想找人结婚,我天真的以为,我会像很多同龄人一样谈恋爱,找到一个人在一起后就可以忘记...
    Nothing小星星阅读 275评论 1 0
  • 加班刚进家门,争取赶着十二点前交今天的作业。每周三是宝宝最爱的美术课,也是我喜欢的美术教学方式。在现如今竞争越来越...
    昵称已被占用了阅读 136评论 0 0