Vue/vant——渲染详情页添加购物车数据渲染到购物车页面,并进行删除数据效果

简介: 渲染详情页添加购物车数据渲染到购物车页面,并进行删除数据效果

添加后的数据渲染在购物车页面

在登陆成功后请求购物车页面数据

Login.vue

setTimeout(() => {
          this.$axios({
            method: "post",
            url: "/login",
            data: {
              username: this.username,
              password: this.password,
            },
          })
            .then((result) => {
              console.log(result);
              if (
                this.username === result.data.data.username ||
                this.password === result.data.data.password
              ) {
                Toast("登陆成功!");
                this.$store.dispatch('updateCartList')
                this.login(result.data.data);
                this.$router.push("/Myfile");
              } else {
                Toast("账号或密码不正确,请重新输入");
                this.pshow = true;
                return (this.show = false);
              }
            })
            .catch((err) => {
              console.log("数据请求错误,请联系工作人员");
              return Toast("404,请联系工作人员");
            });
        }, 1000);

5483fb62c7da4ca89d4995a9df2583b0.png

user.js

actions: {
    updateCartList(
      {commit}
    ){
      Axios({
        url:'/cart',
        data:{},
        method:"get",
        headers:{
          token:true
        }
      }).then(v=>{
        window.sessionStorage.setItem('cart',JSON.stringify(v.data.data)) // 存储一下数据
        commit('noselectAll')        // 添加不全选方法
        // 赋值
        commit('initCartList', v.data.data) // 初始化渲染数据
      })
    }
  },

e80fa0f6a24c437cacd73b378140b250.png

这样写不会每次点击页面都请求数据

使用$bus进行非父子组件传值使用解析

现在这里需要点击添加购物车时把数据添加到购物车里面。步骤如下:

main.js

Vue.prototype.$bus = new Vue();

detaiil.vue

接收使用$emit

b7e2793c99c4412dadf622314bfb060e.png

派发使用$on

b7e2793c99c4412dadf622314bfb060e.png

删除数据

添加成功后当然也需要进行删除,删除代码如下:

cart.js中的action

dodelgoods({
    commit,
    state
  }) {
    Axios({
    url: '/cart/delete',
    method:'POST',
    data: {
      shop_ids: state.selectedAll.join(',')
    },
    header: {
      token: true
    }
    }).then(res => {
    console.log(res);
    })
    commit('delgoods')
  },

Cart.vue

4086a30a039c44e6b5d65b828fcebe95.png

最后把删除事件变更为请求的方法即可完成

8ccd0ae5123c48de8f0766bf55443a13.png

最终看一下实现效果:

f597ca83f7804a3e96b1821c10cc4540.gif

相关文章
|
13天前
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
34 1
|
13天前
|
JavaScript 开发者
在 Vue 3 中使用 Proxy 实现数据的双向绑定
【10月更文挑战第23天】Vue 3利用 `Proxy` 实现了数据的双向绑定,无论是使用内置的指令如 `v-model`,还是通过自定义事件或自定义指令,都能够方便地实现数据与视图之间的双向交互,满足不同场景下的开发需求。
34 1
|
19天前
|
API
vue3知识点:响应式数据的判断
vue3知识点:响应式数据的判断
25 3
|
21天前
|
存储 缓存 JavaScript
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
vue表单案例练习:vue表单创建一行数据及删除数据的实现与理解
42 2
|
1月前
|
JavaScript
vue3,使用watch监听props中的数据
【10月更文挑战第3天】
1000 2
|
17天前
|
JavaScript UED
"Vue实战技巧大揭秘:一招解决路由跳转页面不回顶部难题,让你的单页面应用用户体验飙升!"
【10月更文挑战第23天】在Vue单页面应用中,点击路由跳转时,默认情况下页面不会自动滚动到顶部,这可能影响用户体验。本文通过一个新闻网站的案例,介绍了如何使用Vue-router的全局前置守卫和`scrollBehavior`方法,实现路由跳转时页面自动滚动到顶部的功能,提升用户浏览体验。
52 0
|
29天前
|
JavaScript 前端开发 安全
如何在 Vue 页面中禁止选择、右键、复制及 F12 开发者工具
【10月更文挑战第3天】 在前端开发中,保护页面内容不被随意复制或查看是一个常见需求。本文介绍了如何在 Vue 应用中实现禁止文本选择、右键菜单、复制操作以及 F12 开发者工具的方法。通过结合 CSS 和 JavaScript 事件监听,我们可以增加用户查看和复制内容的难度,尽管无法完全阻止高级用户。适当的防护措施可以为内容提供一层额外的保护,帮助开发者提升页面安全性。
320 0
|
1月前
|
JavaScript 索引
vue 表格数据上下移动并增加背景色
vue 表格数据上下移动并增加背景色
34 0
|
JavaScript 数据安全/隐私保护
work02_vue页面打印水印
work02_vue页面打印水印
343 0
work02_vue页面打印水印
|
3天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。