其实在去年小颖已经写过一篇:
Vue.js实现checkbox的全选和反选
小颖今天在跟着慕课网学习vue的过程中,顺便试试如何在table中实现全选和反选,页面的css样式是直接参考慕课网的样式写的,js是小颖自己写哒,欢迎大家吐槽和点赞,嘻嘻
慕课网demo的 git 地址:
ShoppingCart
页面效果:
具体怎么实现的呢?
因为上篇文章:
使用localstorage来存储页面信息
中已经有写项目是怎么创建的所以小颖在这里就不重复了,其实只是在上篇文章的基础上稍微做了改动:
App.vue文件
<template>
<div id="app">
<router-view/>
</div>
</template>
<script>
export default {
name: 'app'
</script>
<style>
#app {
font-family: 'Avenir', Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
color: #2c3e50;
hgroup,
blockquote,
figure,
form,
fieldset,
input,
legend,
abbr,
button {
margin: 0;
padding: 0;
list-style: none;
margin: 0;
padding: 0;
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
color: inherit;
text-decoration: none;
.checkout-title {
position: relative;
margin-bottom: 41px;
text-align: center;
.checkout-title::before {
position: absolute;
top: 50%;
left: 0;
content: "";
width: 100%;
height: 1px;
background: #ccc;
z-index: 0;
.checkout-title span {
position: relative;
padding: 0 1em;
background-color: #fff;
font-family: "moderat", sans-serif;
font-weight: bold;
font-size: 20px;
color: #605F5F;
z-index: 1;
</style>
home.vue文件
<template>
<div class="container">
<div class="checkout-title">
<span>购物车</span>
</div>
<table class="product_table">
<tbody>
<template v-for="(list,index) in table_list">
<td width="7%" min-width="94px" v-if="index===0">
<input type="checkbox" v-model='checked' v-on:click='checkedAll'></td>
<td width="7%" v-if="index!==0">
<input type="checkbox" v-model='checkList' :value="list.id">
<td width="43%">{{list.product_inf}}</td>
<td width="10%" v-if="index===0">{{list.product_price}}</td>
<td width="10%" v-if="index!==0">¥{{list.product_price}}</td>
<td width="10%">{{list.product_quantity}}</td>
<td width="10%">{{list.total_amount}}</td>
<td width="20%" v-if="index===0">编辑</td>
<td width="20%" v-if="index!==0">
<a href="#" class="update">修改</a>
<a href="#" class="delete">删除</a>
</template>
</tbody>
</table>
<div class="price_total_bottom">
<div class="price_total_ms">
<label>合计:{{allProductTotal}}</label>
<router-link to="/userAddress">结账</router-link>
</div>
</div>
</div>
</template>
<script>
import userAddress from './address'
export default {
components: {
userAddress
data() {
return {
table_list: [{
'id': 0,
'product_inf': '商品信息',
'product_price': '商品金额',
'product_quantity': '商品数量',
'total_amount': '总金额'
'id': '1',
'product_inf': '女士银手链',
'product_price': 120,
'product_quantity': 200,
'total_amount': 24000
'id': '2',
'product_inf': '女士银手镯',
'product_price': 380,
'product_quantity': 200,
'total_amount': 72000
'id': '3',
'product_inf': '女士银耳环',
'product_price': 100,
'product_quantity': 200,
'total_amount': 20000
checked: false,
allProductTotal: null,
checkList: ['1', '3']
methods: {
checkedAll: function() {
var _this = this;
console.log(_this.checkList);
if (_this.checked) { //实现反选
_this.checkList = [];
} else { //实现全选
_this.checkList = [];
_this.table_list.forEach(function(item, index) {
if (index > 0) {
_this.checkList.push(item.id);
watch: { //深度 watcher
'checkList': {
handler: function(val, oldVal) {
if (val.length === this.table_list.length - 1) {
this.checked = true;
} else {
this.checked = false;
deep: true
</script>
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.container {
padding: 69px 0 54px 0;
table {
border-collapse: collapse;
border-color: transparent;
text-align: center;
.product_table,
.product_table tbody {
width: 100%
.product_table tr:first-child {
background: #ece6e6;
color: #e66280;
font-size: 20px;
.product_table td {
border: 1px solid #f3e8e8;
height: 62px;
line-height: 62px;
.product_table a.update:link,
.product_table a.update:visited,
.product_table a.update:hover,
.product_table a.update:active {
color: #1CE24A;
.product_table a.delete:link,
.product_table a.delete:visited,
.product_table a.delete:hover,
.product_table a.delete:active {
color: #ffa700;
.price_total_bottom {
font-size: 20px;
padding: 20px 10px;
.price_total_ms {
text-align: right;
.price_total_bottom .price_total_ms label {
margin-right: 100px;
.price_total_bottom .price_total_ms a {
cursor: default;
text-align: center;
display: inline-block;
font-size: 20px;
color: #fff;
font-weight: bold;
width: 220px;
height: 54px;
line-height: 54px;
border: 0;
background-color: #f71455;
</style>
转载于:https://www.cnblogs.com/yingzi1028/p/7781829.html
其实在去年小颖已经写过一篇:Vue.js实现checkbox的全选和反选 小颖今天在跟着慕课网学习vue的过程中,顺便试试如何在table中实现全选和反选,页面的css样式是直接参考慕课网的样式写的,js是小颖自己写哒,欢迎大家吐槽和点赞,嘻嘻 慕课网demo的 git 地址:ShoppingCart 页面效果:具体怎么实现...
(1)普通全
选
反
选
实现
,通过methods方法
实现
1.首先写
vue
先引入:<script src="https://cdn.jsdelivr.net/npm/
vue
@2.6.14/dist/
vue
.js"></script>
2.接着写静态布局
3.挂载dom
实现
全选和
反
选
需要遍历对各对象的值,我们可以通过方法
实现
,也可以通过计算机域
实现
。
建立好多个
选
项框,对
全选和
反
选
与数组
中
的数据进行绑定——v-model。(
反
选
通过@change = ”inverses“ 声明一个方法)
通过v-for=”(item,index)in data“ :key=”index“ 遍历对象获取其
中
的值。
在
中
set()
中
获取全
选
框
中
状态。get()则是获取每个
选
项
中
的状态是true
在开发项目的过程当
中
,特别是开发后台管理系统时,会有很多的数据等待管理员去统一管理,所以有时候还需要将一些数据导出,然后打印,这是很有必要的,因为数据可以帮助分析这个产品是否具有价值。
我这里演示后台返回的数据格式如下:
data:{
list:[
{id:240201,code:'nqctedp80pc8',desc:'推广',typ...
对于
Vue
3 嵌套表格
中
的
全选和
反
选
功能,你可以按照以下步骤
实现
:
1. 在父表格组件
中
定义一个
选
中
项的数组,例如:`selectedRows: []`。
2. 在父表格
中
的每一行
中
添加一个复
选
框,并绑定一个 `v-model` 指令到该行对应数据的
选
中
状态,例如:`<input type="checkbox" v-model="rowData.selected">`。
3. 在表头
中
添加一个全
选
复
选
框,并绑定一个 `v-model` 指令到一个 Boolean 类型的变量,例如:`<input type="checkbox" v-model="allSelected">`。
4. 在全
选
复
选
框的 `change` 事件
中
,将所有数据的
选
中
状态设为全
选
复
选
框的
选
中
状态,并通过 `$emit` 方法向子组件发送消息,例如:
selectAll() {
this.selectedRows = this.
table
Data.map(row => {
row.selected = this.allSelected;
return row;
this.$emit('select-all', this.allSelected);
5. 在
选
中
项数组的 `watch`
中
,计算已
选
中
的项数,并更新全
选
复
选
框的
选
中
状态,例如:
watch: {
selectedRows() {
const selectedCount = this.selectedRows.filter(row => row.selected).length;
this.allSelected = selectedCount === this.
table
Data.length;
6. 在子表格组件
中
定义一个
选
中
项的数组,并通过 `props` 接收父组件传递的
选
中
状态和
选
中
项数组,例如:
props: {
allSelected: Boolean,
selectedRows: Array
data() {
return {
innerSelectedRows: []
7. 在子表格
中
的每一行
中
添加一个复
选
框,并绑定一个 `v-model` 指令到该行对应数据的
选
中
状态,例如:`<input type="checkbox" v-model="rowData.selected">`。
8. 在表头
中
添加一个全
选
复
选
框,并绑定一个 `v-model` 指令到一个 Boolean 类型的变量,例如:`<input type="checkbox" v-model="allSelected">`。
9. 在父组件向子组件发送消息的事件
中
,将子组件的
选
中
项数组设为父组件的
选
中
项数组,并根据父组件的全
选
状态更新子组件的全
选
状态,例如:
onSelectAll(allSelected) {
this.innerSelectedRows = this.
table
Data.map(row => {
row.selected = allSelected;
return row;
this.allSelected = allSelected;
10. 在子组件
选
中
项数组的 `watch`
中
,计算已
选
中
的项数,并更新父组件的
选
中
项数组和全
选
状态,例如:
watch: {
innerSelectedRows() {
const selectedCount = this.innerSelectedRows.filter(row => row.selected).length;
this.selectedRows.splice(this.$attrs.index, 1, ...this.innerSelectedRows);
this.$emit('select-all', selectedCount === this.innerSelectedRows.length);
以上就是
实现
Vue
3 嵌套表格
中
全选和
反
选
功能的基本步骤。需要注意的是,在子组件
中
,需要通过 `$attrs` 获取到父组件传递的索引值,以便更新父组件的
选
中
项数组。
关于C++程序运行程序是出现的this application has requested the runtime to terminate it in an unusual way. 异常分析...