添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

其实在去年小颖已经写过一篇: 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">&yen;{{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. 异常分析...