vue开发购物车,解决全选单选问题
实现全选单选,在vue中无法通过this获取input中的checkbox的checked属性,但是可以通过vue对input的特殊方式v-model来实现对应数据的绑定,同样也可以通过这种方式实现购物车全选,单选的效果。
大体内容如下:
主要是通过checkbox以及v-if v-else实现内容的隐藏与显示
当全选对应的checkbox为选中状态,在这里指的是:
<th>全选<input type="checkbox" @click="handleChecked()" v-model="allChecked"/></th>
注解:
(1)allChecked:被封装成一个boolean类型的值,当选中时被设置成true,反之为对立面。
(2)handleChecked():是一个函数,用来处理触发事件,同时实现对应的效果,如改变子的checkbox的状态。
(3)一个比较巧妙的转换boolean数据对立面的方法:this.allChecked = !this.allChecked;
(4)购物车总价显示与否的实现方法:通过v-if与v-else来判断,前提也是有一个boolean类型的值作为逻辑控制的标志;
本方法的使用环境如下:
1、data的封装
- data() {
- return {
- //全选
- allChecked:false,
- //总计一栏是否显示的标记
- displayMoney: false,
- // 购物清单
- list: [{
- checked:false,
- id: 1,
- name: '发动机',
- price: 180,
- count: 1,
- Stotal: 180
- },
- {
- checked:false,
- id: 2,
- name: '燃油机',
- price: 200,
- count: 1,
- Stotal: 200
- },
- {
- checked:false,
- id: 3,
- name: '滤清',
- price: 500,
- count: 1,
- Stotal: 500
- }
- ]
- }
- },
2、html部分
- <div id="" v-if="list.length">
- <table class="table_border">
- <thead>
- <tr class="tip">
- <th>全选<input type="checkbox" @click="handleChecked()" v-model="allChecked"/></th>
- <th>商品编号</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" v-model="item.checked" name="all"/></td>
- <td>{{ index + 1}}</td>
- <td>{{ item.name }}</td>
- <td>¥{{ item.price }}</td>
- <td>
- <button @click="handleReduce(index)" :disabled="item.count===1">-</button>
- <input type="text" v-model="item.count" readonly="readonly" />
- <button @click="handleAdd(index)">+</button>
- </td>
- <td>¥{{ item.Stotal }}</td>
- <td>
- <el-button @click="handleRemove(index)" type="danger" icon="el-icon-delete" circle></el-button>
- </td>
- </tr>
- <tr>
- <td colspan="4"></td>
- <td colspan="3">
- 总价 :¥
- <span v-if="displayMoney=true">{{totalPrice}}</span>
- <span v-else="displayMoney=false">0</span>
- </td>
- </tr>
- </tbody>
- </table>
- </div>
- <div id="" v-else>
- 购物车为空
- </div>
3、核心方法部分
- handleChecked: function(item) {
- //全选
- if(this.allChecked==false) {
- for(var i = 0; i < this.list.length; i++) {
- var item = this.list[i];
- item.checked = true;
- }
- } else { //取消全选
- for(var i = 0; i < this.list.length; i++) {
- var item = this.list[i];
- item.checked = false;
- }
- }
- this.allChecked = !this.allChecked;
- }
完整代码见:https://download.csdn.net/download/colourfultiger/10516616
vue开发购物车,解决全选单选问题的更多相关文章
- vue+vant 购物车的全选和反选
https://blog.csdn.net/wjswangjinsheng/article/details/91392694
- Flutter实战视频-移动电商-60.购物车_全选按钮的交互效果制作
60.购物车_全选按钮的交互效果制作 主要做全选和复选框的这两个功能 provide/cart.dart 业务逻辑写到provide里面 先持久化取出来字符串,把字符串编程list.循环list ca ...
- VUE实现简单的全选/全不选
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- vue+vant实现购物车的全选和反选业务,带你研究购物车的那些细节!
前言 喜欢购物的小伙伴看过来,你们期待已久的购物车来啦!相信小伙伴逛淘宝时最擅长的就是加入购物车了,那购物车是如何实现商品全选反选的呢?今天就带你们研究购物车的源码,以vue+vant为例. 正文 首 ...
- jquery-防多店铺购物车结算全选,单选,及删除,价格计算
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- Android中购物车的全选、反选、问题和计算价格
此Demo主要解决的是购物车中的全选,反选计算价格和选中的条目个数的问题,当选中几条时,点击反选,会把当先选中的变为不选中,把不选中的变为选中.点击全选会全部选中,再次点击时,变为全部不选中. //- ...
- vue中的checkbox全选和反选
前几天有个博客园的朋友问小颖,小颖之前写的vue2.0在table中实现全选和反选 .Vue.js实现checkbox的全选和反选,为什么他将里面的js复制下来,但是实现不了全选和反选.小颖当时看他 ...
- vue的el-select标签全选以及出现需要有禁用选项
首先说一下遇到这种问题的解决思路吧,很简单先去https://element.eleme.cn/#/zh-CN 这个官网上找到对应的需求,然后就是拼接数据的问题. 以下是全选的例子: <el-s ...
- 邮箱性质--全选单选的操作和传值 用属性的name传值
封装类 using System; using System.Collections.Generic; using System.Web; /// <summary> /// Ha 的摘要 ...
随机推荐
- 怎么用SQL语句查数据库中某一列是否有重复项
SELECT 某一列, COUNT( 某一列 ) FROM 表 GROUP BY 某一列 HAVING COUNT( 某一列 ) 〉1 这样查询出来的结果, 就是 有重复, 而且 重复的数量.
- 填报志愿(codevs 2930)
题目描述 Description 高考已经结束,而志愿填报正在进行中- 吴校长的学校里有n位同学,每位同学有ki个愿意去的大学.而在吴老师的省份中,有m所大学有招生名额.根据往年的经验,对于每所大学( ...
- UVa10234 Race
递推,设有i个人排在第一名,剩下的人排在后面,方案有f[i]种,则f[i]=sum(c[n][i]*f[n-i]) 1<=i<=n /*by SilverN*/ #include<a ...
- Bootstrap开启模态框后对数据处理(标记模态框的开启与关闭状态)
JS用全局变量标记状态,方法中动态修改全局变量以标记状态是一个重要思想. 需求:组合条件查询数据,查询完之后填充到模态框中,开启模态框,模态框中有组合条件查询,此时查询只需要更新模态框表格数据不需要开 ...
- windows软件配置
1 安装jdk 配置环境变量 新建JAVA_HOME:D:\Program Files\Java\jdk1.8.0_151 新建JRE_HOME:D:\Program Files\Java\jre1. ...
- 迁移桌面程序到MS Store(8)——通过APPX下载Win32Component
在上一篇<迁移桌面程序到MS Store(7)——APPX + Service>中,我们提到将desktop application拆分成UI Client+Service两部分.其中UI ...
- for 循环进化史
ECMAScript 6已经逐渐普及,经过二十多年的改进,很多功能也有了更成熟的语句,比如 for 循环 这篇博客将介绍一下从最初的 for 循环,到 ES6 的 for-of 等四种遍历方法 先定义 ...
- Swift的可选链,类型转换和扩展
可选链(Optional Chaining) 可选链是一种请求或调用属性.方法,子脚本的过程. 可选性体现于请求或调用的目标当前可能为nil.若不为nil则成功调用.否则返回nil并将链失效. 调用可 ...
- mysql 安装与启动
1.下载mysql installer 2.安装 一直点next,直到finish. 3.安装时的配置 安装完后,选择立即开始配置. 选择standard configuration 勾选安装mysq ...
- Ubuntu搭建Android开发环境
前言 由于迁移到新的笔记本,所以Android开发环境须要又一次配置了.android官网有配置教程,我正好回想一遍 配置Java环境 下载jdk.官网地址:http://www.oracle.com ...