美文网首页
地址模块实现

地址模块实现

作者: 飞飞廉 | 来源:发表于2018-01-05 16:41 被阅读0次

地址页面:


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">

相关文章

  • 地址模块实现

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

  • Flutter基础篇01--实现一个综合页面

    实现下面这个综合页面demo 界面分析: 1、可拆分四个模块:图片模块、地址模块、按钮模块、文本模块2、由于文本模...

  • 16 -Flask构建弹幕微电影网站- 会员模块实现

    本章内容: 会员模块实现已上线演示地址: http://movie.mtianyan.cn项目源码地址:https...

  • Rewrite实例

    1.什么是Rewrite 实现url地址重写或url地址跳转 2.Rewrite相关模块 set设置变量if 负...

  • 第九天 单页多应用及前端框架JM介绍

    1、单页多应用: 通过异步传输功能实现单页多模块,所谓单页多模块就是在一个地址下可以实现多个功能 2、前端实现可通...

  • 认识node核心模块--全局对象及Cluster

    原文地址在我的博客,转载请注明出处,谢谢! node 模块是node 完成强大功能的实现者。node 的核心模块包...

  • python 模块之pickle

    地址 pickle 模块可以看作是cPickle 的python实现,cPick效率肯定比pickle快的多。但是...

  • 每周一个 Python 模块 | bisect

    专栏地址:每周一个 Python 模块 bisect 模块,用于维护有序列表。实现了一个算法用于插入元素到有序列表...

  • iOS -- 低功耗蓝牙

    蓝牙介绍:使用的是网上购买的一个简单的蓝牙模块蓝牙模块地址:蓝牙模块地址USB转TTL:转接模块地址 AT-09蓝...

  • Flutter布局尝试

    官方的例子实现 1. 实现图片模块 2. 实现标题模块 3. 实现按钮模块 4. 实现正文模块 5. 整合所有模块...

网友评论

      本文标题:地址模块实现

      本文链接:https://www.haomeiwen.com/subject/rydsnxtx.html