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

相关文章
|
JavaScript 前端开发 算法
vue渲染页面的原理
vue渲染页面的原理
368 56
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
683 161
|
JavaScript 数据管理 Java
在 Vue 3 中使用 Proxy 实现数据双向绑定的性能如何?
【10月更文挑战第23天】Vue 3中使用Proxy实现数据双向绑定在多个方面都带来了性能的提升,从更高效的响应式追踪、更好的初始化性能、对数组操作的优化到更优的内存管理等,使得Vue 3在处理复杂的应用场景和大量数据时能够更加高效和稳定地运行。
711 156
|
SQL JavaScript 前端开发
Vue实现动态数据透视表(交叉表)
Vue实现动态数据透视表(交叉表)
556 13
|
敏捷开发 人工智能 JavaScript
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
Figma-Low-Code 是一个开源项目,能够直接将 Figma 设计转换为 Vue.js 应用程序,减少设计师与开发者之间的交接时间,支持低代码渲染和数据绑定。
1485 3
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
|
JavaScript 前端开发 API
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储 数据采集 供应链
属性描述符初探——Vue实现数据劫持的基础
属性描述符还有很多内容可以挖掘,比如defineProperty与Proxy的区别,比如vue2与vue3实现数据劫持的方式有什么不同,实现效果有哪些差异等,这篇博文只是入门,以后有时间再深挖。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
监控 JavaScript 算法
深度剖析 Vue.js 响应式原理:从数据劫持到视图更新的全流程详解
本文深入解析Vue.js的响应式机制,从数据劫持到视图更新的全过程,详细讲解了其实现原理和运作流程。
|
分布式计算 JavaScript 前端开发
vue学习第8章(vue的购物车案例)
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,正向全栈进发。本篇分享一个综合练习小demo,包括目录结构、HTML、JS及CSS代码,通过增删商品实现总价计算。关注我,获取更多前端知识!🎉🎉🎉
193 1
|
JavaScript 数据安全/隐私保护
work02_vue页面打印水印
work02_vue页面打印水印
474 0
work02_vue页面打印水印

热门文章

最新文章