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

Vue中Table组件Select的勾选和取消勾选事件详解

程序员文章站 2023-12-04 22:24:40
简述 之间设计的界面中使用的是复选框控件,但是经过对官网了一些了解,使我们更加倾向于使用一些官网已经封装好的事件,就比如table组件的select勾选和取消勾选的这样一...

简述

之间设计的界面中使用的是复选框控件,但是经过对官网了一些了解,使我们更加倾向于使用一些官网已经封装好的事件,就比如table组件的select勾选和取消勾选的这样一个事件。

勾选

首先我们需要说一下这个需求,如下图:

Vue中Table组件Select的勾选和取消勾选事件详解

勾选要实现如下的一个效果:对左侧table的内容进行勾选,然后勾选行的数据传给右侧的table中。

实现代码如下:

============1、按照官网封装好的样式去写table组件=======
<template>
 <div>
 <table></table>
 </div>
</template>

<script>
 import axios from "axios";
 export default{
 data(){
 return{
 hotfooddata:[],
 selectedfooddata:[],
 columnhotfood:[
  {
  title:"菜名",
  key:"foodname"
  },
  {
  title:"份数(默认为不限份数,文本框输入限制)",
  key:"perlimitfood",
  width:300.
  align:"center",
  ///////////////////////数据双向绑定/////////////////////////////
  render:(h,params)=>{
  return h("input",{
  props:{
   min:0,
   value:this.hotfooddata[params.index].perlimitfood //设置数字
  },
  on:{
   "on-change":event=>{
   this.hotfooddata[params.index].permitfood=event.target.value;
   }
  }
  });
  }
  },
  {
  type:"selection",
  width:100,
  align:"center"
  },
 ],
 column2: [
   {
    title: "菜名",
    key: "foodname"
   },
   {
    title: "限制份数(默认为不限份数)",
    key: "perlimitfood"
   }
   ]
 }
 methods:{
 }
 };
</script>

============2、向绑定数据中传送数据(后端传送数据、方法中书写)=============
 add() {
  var vm = this;
  //配置热菜菜单
  var urldata =
  "http://192.168.21.210:8016/food/queryfoodbyshiid?foodtn=18";
  axios.get(urldata).then(function(response) {
  vm.hotfooddata = response.data;
  });
 },
 created() {
  this.add();
 }

 
===========3、写勾选传输数据的事件==============
<table border :columns="columnmainfood" :data="mainfooddata" @on-select="selectrow" @on-select-all="selectallrow" ></table>

method中:

//点击左边表格触发事件,向右侧表格添加元素
 selectrow(selection, row) {
  this.selectrowdata = row;

  this.selectedfooddata.push(this.selectrowdata);
  console.log(this.selectedfooddata);
 },

取消勾选

取消勾选的事件和勾选事件类似,如下(之前table组件的创建代码和数据传入不再重复)

<table border :columns="columnmainfood" :data="mainfooddata" @on-select-cancel="selectcancel" ></table>

method中:

//点击左侧表格,取消勾选,右侧数据也发生改变
 selectcancel(selection, row) {
  console.log("看一下row---------", row);
  this.selectedfooddata.pop(row);
 }

总结

还差的远呢,加油吧!

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