登录  /  注册
首页 > web前端 > js教程 > 正文

vue2实现购物车与地址选配案例分析

php中世界最好的语言
发布: 2018-05-11 13:49:01
原创
1619人浏览过

这次给大家带来vue2实现购物车与地址选配案例分析,vue2实现购物车与地址选配的注意事项有哪些,下面就是实战案例,一起来看一下。

首先,vue基础js写法

new Vue({
  el:"#app",
  //模型
  data:{
  },
  filters:{
  },
  mounted:function(){
    this.$nextTick(function(){
    //初始化调用
    });
  },
  computed:{
    //实时计算
  },
  methods:{
  }
});
登录后复制

v-for

登录后复制
登录后复制
登录后复制
登录后复制
  •   

    {{item.productName}}

  • v-model

    (实时更新)

    <input><p>{{item.productQuantity}}</p>
    登录后复制

    v-bind

    <a>
    <!--可通过更改item.checked的值设置是否选中-->
    <!--必须用v-bind 不可直接在class里面直接使用{{}}-->
    <!--v-bind:class= 可简写为 :class= --></a>
    登录后复制

    filters过滤器的使用

    1.html引用方式

    <p>{{item.productPrice | money('元')}}</p>
    登录后复制

    2.过滤器

    filters:{
      formatMoney:function(value,type){
        return "¥"+value.toFixed(2)+ type;
      }
    },
    登录后复制

    3.全局过滤器(写在new Vue的外面)

    Vue.filter("money",function(value,type){
      return "¥"+value.toFixed(2) + type; //保留两位小数 结果eg:¥19.00元
    });
    登录后复制

    调用methods中的方法:

    @click="method(param)"
    //或者
    @click="delFlag=false"
    @click="limitNum=addressList.length"
    登录后复制

    computed 实时计算

    如下:默认显示三条数据,点击more 显示所有

    登录后复制
    登录后复制
    登录后复制
    登录后复制
  •   more                

    data:{     limitNum:3   }, computed:{   filterAddress:function(){     return this.addressList.slice(0,this.limitNum);   } },

    先提出一两个经典的实例

    1.以下实现了对循环卡片的点击 选中

    登录后复制
    登录后复制
    登录后复制
    登录后复制
  • 2.以下实现了对固定卡片的点击 选中

    登录后复制
    登录后复制
    登录后复制
    登录后复制
        
    •    

      标准配送

         

      Free

        
    •  >   
    •    

      高级配送

         

      180

        
    •  
     

    题外话:由于本人小白,学一点是一点,额外记录一下辅助弹出框 遮罩层的写法

    <p></p>
    登录后复制

    vue2的js语法 贴几个 方便查用

    1.调用后端方法

    var _this = this;
    this.$http.get("data/address.json").then(function(response){
        _this.addressList = response; //这里不能直接用this 此this非彼this 所以只能声明_this
    }); 
    //以下为ES6写法,就可以直接用this了
    let _this = this;  //没用,就放这看看~
    this.$http.get("data/cartData.json",{"id":123}).then(res=&gt;{
      this.productList = res.data.result.list;
    });
    登录后复制

    2.forEach循环

    this.productList.forEach(function(item,index){
      if(typeof item.checked == 'undefined'){ 
      //如果item中没有checked属性 在item对象中添加checked属性,值为true
        _this.$set(item,"checked",true);//局部注册
        Vue.set(item,"checked",true);//全局注册
      }
    });
    登录后复制

    相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

    推荐阅读:

    vue实现搜索列表内容

    axios发送post请求提交图片表单步骤详解

  • 以上就是vue2实现购物车与地址选配案例分析的详细内容,更多请关注php中文网其它相关文章!

    智能AI问答
    PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    关于CSS思维导图的课件在哪? 课件
    凡人来自于2024-04-16 10:10:18
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习
    PHP中文网抖音号
    发现有趣的

    Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号