Vue电商项目--个人中心

个人中心二级路由搭建

Vue电商项目--个人中心_第1张图片配置路由

Vue电商项目--个人中心_第2张图片界面如上

我们现在要实现一种方式就是点击右侧的,左侧发生变化

先把这部分拆走,拆分成俩部分

Vue电商项目--个人中心_第3张图片Vue电商项目--个人中心_第4张图片 但是很明显报错了,错误是图片路径的问题

Vue电商项目--个人中心_第5张图片 Vue电商项目--个人中心_第6张图片 然后就没有问题了。

但是我们这块不是使用组件的方式,而是使用二级路由的方式

Vue电商项目--个人中心_第7张图片 Vue电商项目--个人中心_第8张图片

然后回到个人中心页面,配置路由

Vue电商项目--个人中心_第9张图片

 然后就完事了

我的订单

就是我们当当做的个人中心页都是静态的。现在我们需要修改成动态的

写接口

获取我的订单列表

请求地址

/api/order/auth/{page}/{limit}

请求方式

GET

参数类型

参数名称

类型

是否必选

描述

page

string

Y

页码

limit

string

Y

每页显示数量

返回示例

成功:

{

    "code": 200,

    "message": "成功",

    "data": {

        "records": [

            {

                "id": 70,

                "consignee": "admin",

                "consigneeTel": "15011111111",

                "totalAmount": 29495,

                "orderStatus": "UNPAID",

                "userId": 2,

                "paymentWay": "ONLINE",

                "deliveryAddress": "北京市昌平区2",

                "orderComment": "",

                "outTradeNo": "ATGUIGU1584247289311481",

                "tradeBody": "Apple iPhone 11 (A2223) 128GB手机 双卡双待 A",

                "createTime": "2020-03-15 12:41:29",

                "expireTime": "2020-03-16 12:41:29",

                "processStatus": "UNPAID",

                "trackingNo": null,

                "parentOrderId": null,

                "imgUrl": null,

                "orderDetailList": [

                    {

                        "id": 81,

                        "orderId": 70,

                        "skuId": 2,

                        "skuName": "Apple iPhone 11 (A2223) 64GB 红色",

                        "imgUrl": "http://192.168.200.128:8080/xxx.jpg",

                        "orderPrice": 5499,

                        "skuNum": 1,

                        "hasStock": null

                    },

                    …

                ],

                "orderStatusName": "未支付",

                "wareId": null

            },

            …

        ],

        "total": 41,

        "size": 2,

        "current": 1,

        "pages": 21

    },

    "ok": true

}

Vue电商项目--个人中心_第10张图片去掉api,写错了

Vue电商项目--个人中心_第11张图片 然后就能拿到数据,并将它渲染到页面上

Vue电商项目--个人中心_第12张图片 Vue电商项目--个人中心_第13张图片 虽然渲染到页面上,但有些内容并没有合并

Vue电商项目--个人中心_第14张图片 修改了一下代码,现在展示的是正确的。


                  
                    
                      
{{cart.skuName}} x{{cart.skuNum}} 售后申请
{{order.consignee}}
  • 总金额¥{{order.totalAmount}}.00
  • 在线支付
{{ order.orderStatusName }}

然后写后面的分页器的功能

Vue电商项目--个人中心_第15张图片

 然后就能实现分页器的功能

Vue电商项目--个人中心_第16张图片

我看了一下以前的笔记,这个分页器是被配置的全局组件

未登录的导航守卫判断

优化了一些还没有实现的功能

Vue电商项目--个人中心_第17张图片还存在一个问题,未登陆访问,交易相关(trade)、支付相关(pay,paysuccess)、用户中心(center)相关跳转应该先到登陆页面 

Vue电商项目--个人中心_第18张图片

我们可以通过这种方式。保存我们原先想要去的路由地址

Vue电商项目--个人中心_第19张图片反编译一下,把未登录的时候向去而没有去成的信息,存储与地址栏中

而我们此时就不能傻乎乎的直接跳home了

就是看路由当中是否包含query参数,有:跳到query参数指定路由,没有,跳到home中 

Vue电商项目--个人中心_第20张图片

当当找到自己写的一个bug,就是无论点击哪个都是/login页面 这个是因为我其中,toPath.indexOf('/pay') != 1 这个条件判断是有问题的。应该将 != 1 修改为 !== -1。这样才能正确检查是否包含 '/pay'。

正确代码如下:

router.beforeEach(async (to,from,next)=>{
        next();
    let token=store.state.user.token;
    let name=store.state.user.userInfo.name;
    if(token){
        if(to.path=='/login'){
            next('/home')
        }else{
            // 如果有用户名
            if(name){
                next();
            }else{
                try {
                    // 没有用户名,派发action让仓库存储用户信息在跳转
                await store.dispatch('getUserInfo');
                next();
                } catch (error) {
                    // token过期
                    // 清除token
                    await store.dispatch('userLogout');
                    next('/login')
                }
            }
        }
    }else{
        // 卡登录,不能跳转交易、支付,个人中心方面的页面
        let toPath=to.path;
        console.log(toPath);
        if(toPath.indexOf('/trade')!=-1||toPath.indexOf('/pay')!=-1||toPath.indexOf('/center')!=-1){
            next('/login?redirect='+toPath);
        }else{
             // 去的不是这些页面,那就放行
             next();
        }

    }
})

用户登录(路由独享与组件内守卫)

刚刚考虑了用户没有登录的情况,现在考虑如果用户登录了。想paysuccess肯定就是不能打开的

。我们这里需要使用路由独享守卫(只负责自己路由的)

Vue电商项目--个人中心_第21张图片

这行代码的意思是如果你是从购物车来的,那就放行。否则停留在当前

 Vue电商项目--个人中心_第22张图片

 通过这种方式来管理,当然我们除了这种方式。我们也可以采用组件内守卫

Vue电商项目--个人中心_第23张图片

 Vue电商项目--个人中心_第24张图片

你可能感兴趣的:(前端框架Vue2+Vue3,vue.js,前端,javascript)