本文实例讲述了Vue.js实现的购物车功能。分享给大家供大家参考,具体如下:
使用计算属性,内置指令,方法等基础知识开发购物车。
需求分析:展示一个已经加入购物车的商品列表,包含商品名称、商品单价、购买数量和操作,以及最后确定是否选中商品的功能,总价格为选中商品的价格,够买数量可以增加减少,商品可以从购物车中移除。效果如图所示:
——实例来自《Vue.js实战》第五章
逻辑整理:vue实例定义一个数组list存放商品信息,定义方法与减少按钮,增加按钮等联系,动态改变商品数量,通过handleRemove()移除list中的值;利用each()遍历所有type='checkbox'的input,修改它们的状态,最后用totalPrices()计算商品总价格。
index.html
<div id="app">
<template v-if="list.length">
<table>
<thead>
<tr>
<th></th>
<th>商品名称</th>
<th>商品单价</th>
<th>购买数量</th>
<th>操作</th>
<th><input type="checkbox" name="list" @click="checkBox()" id="checkBox"></th>
</tr>
</thead>
<tbody>
<tr v-for="(item, index) in list">
<td>{{ index + 1 }}</td>
<td>{{ item.name }}</td>
<td>{{ item.price }}</td>
<td>
<button
@click="handleReduce(index)"
:disabled="item.count === 1" class="btn"> - </button>
{{ item.count }}
<button @click="handleAdd(index)" class="btn"> + </button>
</td>
<td>
<button @click="handleRemove(index)" class="btns">移除</button>
</td>
<td style="text-align: center;">
<input type="checkbox" name="list" @click="totalPrices()">
</td>
</tr>
</tbody>
</table>
<div id="price">总价:¥{{totalPrice}}</div>
</template>
<div v-else>购物车为空</div>
</div>
style.css
*{
margin: 0px;
padding: 0px;
}
[v-cloak] {
display: none;
}
#app{
width: 200px;
height: 200px;
margin: 10px auto;
text-align: center;
}
#price{
width: 457px;
height: 40px;
border: 1px solid #e9e9e9;
border-top: 0;
line-height: 40px;
}
table{
border: 1px solid #e9e9e9;
border-collapse: collapse;
border-spacing: 0;
empty-cells: show;
}
th,td{
padding: 8px 16px;
border:1px solid #e9e9e9e9;
text-align: left;
}
th{
background: #f7f7f7;
color: #5c6c77;
font-weight: 600;
white-space: nowrap;
}
.btn{
width: 20px;
height: 20px;
border-radius: 50%;
border:1px solid #cccccc;
background: #ffffff;
color: #778899;
}
.btns{
width: 40px;
height: 20px;
border-radius: 5px;
border:1px solid #cccccc;
background: #ffffff;
color: #778899;
line-height: 20px;
}
app.js
var app=new Vue({
el:'#app',
data:{
list: [
{
id:1,
name:'iPhone 7',
price:6188,
count:1
},
{
id:2,
name:'iPad Pro',
price:5888,
count:1
},
{
id:3,
name:'MaxBook Pro',
price:21488,
count:1
}
],
totalPrice: 0
},
methods:{
handleReduce: function (index) {//减少按钮
if(this.list[index].count === 1){
return;
}
this.list[index].count--;
this.$options.methods.totalPrices();
},
handleAdd: function (index) {//增加按钮
this.list[index].count++;
this.$options.methods.totalPrices();
},
handleRemove: function (index) {//移除按钮
this.list.splice(index, 1);
$("tr").eq(index+1).remove("input[type='checkbox']");
this.$options.methods.totalPrices();
},
checkBox: function (){//选中状态
if($("#checkBox").is(':checked')==true){
$("input[type='checkbox']").each(function(){
$("input[type='checkbox']").attr("checked",true);
});
}else{
$("input[type='checkbox']").each(function(){
$("input[type='checkbox']").attr("checked",false);
});
}
this.$options.methods.totalPrices();
},
totalPrices: function (){//计算总价格
var total = 0;
for(var i = 0;i < app.list.length;i++){
var item = app.list[i];
if($("input[type='checkbox']").eq(i+1).is(':checked')){
total += item.price * item.count;
}
}
app.totalPrice = total.toString().replace(/\B("color: #0000ff">https://github.com/GitHubVikas/Yao/tree/master/DemoOne
希望本文所述对大家vue.js程序设计有所帮助。
Vue.js,购物车
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
