欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Vue实现本地购物车功能

程序员文章站 2022-09-04 15:41:37
本文实例为大家分享了vue实现本地购物车功能的具体代码,供大家参考,具体内容如下 功能分析 : v-for显示商品名字,价格,数量和对商品进行操作,全选的功能 结构仍然...

本文实例为大家分享了vue实现本地购物车功能的具体代码,供大家参考,具体内容如下

功能分析 : v-for显示商品名字,价格,数量和对商品进行操作,全选的功能
结构仍然分成 : index.html , index.js , style.css

index.html

<!doctype html>
<html lang="en">
<head>
 <meta charset="utf-8">
 <title>购物车实例</title>
 <link rel="stylesheet" href="style.css" >
</head>
<body>
 <div id="app" v-cloak>
 <template v-if="list.length">
 <table>
 <thead>
 <tr>
 <th><input type="checkbox" @click='checkall' :checked='allcheck'></th>
 <th>序号</th>
 <th>商品名称</th>
 <th>商品单价</th> 
 <th>购买数量</th> 
 <th>操作</th> 
 </tr>
 </thead>
 <tbody>
 <tr v-for="(item,index) in list">
 <td><input type="checkbox" :checked='item.ischecked' @click="singlecheck(index)"></td>
 <td>{{index + 1}}</td>
 <td>{{item.name}}</td>
 <td>{{item.price}}</td>
 <td>
 <button @click="handlereduce(index)" :disable="item.count === 1 ">-</button>
 {{item.count}}
 <button @click="handleadd(index)">+</button>
 </td>
 <td>
 <button @click="handleremove">移除</button>
 </td>
 </tr>
 </tbody>
 </table>
 <div>总价 : ¥{{totalprice}}</div>
 </template>
 <div v-else>购物车为空</div>

 </div>
</body>
<!-- 通过cdn引入-->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<script src="index.js"></script>
</html>

index.js

const app = new vue({
 el : '#app',
 data : {
 allcheck:false,
 list : [
 {
 id: 1 ,
 name :'iphone 8 ',
 price: 6188 ,
 count: 1 ,
 ischecked : false
 },
 {
 id: 2 ,
 name :'小米 8 ',
 price: 5888 ,
 count: 1 ,
 ischecked : false
 },
 {
 id: 3 ,
 name :'ipad pro ',
 price: 11000 ,
 count: 1 ,
 ischecked : false
 },
 {
 id: 4 ,
 name :'雷神se9',
 price: 6188 ,
 count: 10 ,
 ischecked : false
 },
 ]
 },
 computed : {
 //通过计算属性获取总价格
 totalprice:function() {
 let total = 0;
 const newarr = this.list.filter(value => {
 return value.ischecked == true
 })
 for(var i = 0 ;i<newarr.length;i++) {
 total += this.list[i].price * this.list[i].count
 }
 //返回一个符合千分位格式的金额数
 //return total.tostring().replace(/\b(?=(\d{3})+$)/g,',')
 return total
 }
 },
 methods : {
 //减法
 handlereduce:function(index) {
 if(this.list[index].count === 1) return ;
 this.list[index].count--;
 },
 //加法
 handleadd:function(index) {
 this.list[index].count++
 },
 //移除
 handleremove:function(index) {
 this.list.splice(index,1)
 },
 //全选
 checkall() {
 this.allcheck = !this.allcheck
 this.list.foreach(value => {
 value.ischecked = this.allcheck
 })
 },
 //单选,当全部选中时,改变全选按钮的状态
 singlecheck(index) {
 this.list[index].ischecked = !this.list[index].ischecked
 const selectdata = this.list.filter(value => {
 return value.ischecked == true
 })
 this.allcheck = selectdata.length === this.list.length ? true : false
 }
 }
})

style.css

[v-cloak] {
 display: none;
}
table {
 border: 1px solid #e9e9e9;
 border-collapse: collapse;
 border-spacing: 0;
 empty-cells: show;
}
th,td {
 padding: 8px 16px;
 border: 1px solid #e9e9e9;
 text-align: left;
}
th {
 background: yellowgreen;
 color: #5c6b77;
 font-weight: 600;
 white-space: nowrap;
}

效果图如下

Vue实现本地购物车功能

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。