vue中实现可编辑table及其中加入下拉选项

 更新时间:2022年08月13日 15:29:28   作者:等樱花的龙猫  
这篇文章主要介绍了vue中实现可编辑table及其中加入下拉选项,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

可编辑table及其中加入下拉选项

<template>
    <div>
    
        <el-table :data="tabledatas" border>
            <el-table-column label="姓名">
                <template slot-scope="scope">
                    <el-input placeholder="请输入内容" v-show="scope.row.show" v-model="scope.row.name"></el-input>
                    <span v-show="!scope.row.show">{{scope.row.name}}</span>
                </template>
            </el-table-column>
            
            <el-table-column label="年龄">
                <template slot-scope="scope">
                    <el-input placeholder="请输入内容" v-show="scope.row.show" v-model="scope.row.age"></el-input>
                    <span v-show="!scope.row.show">{{scope.row.age}}</span>
                </template>
            </el-table-column>
            <el-table-column label="地址">
                <template slot-scope="scope">
                    <el-input placeholder="请输入内容" v-show="scope.row.show" v-model="scope.row.address"></el-input>
                    <span v-show="!scope.row.show">{{scope.row.address}}</span>
                </template>
            </el-table-column>
            <el-table-column label="学籍">
              <template slot-scope="scope">
                <span v-show="!scope.row.show">{{scope.row.stu}}</span>
              <el-select v-model="scope.row.stu" placeholder="请选择" v-show="scope.row.show" >
              
                <el-option
                  v-for="item in options"
                  :key="item.stu"
                  :label="item.stu"
                  :value="item.stu">
                </el-option>
              </el-select>
              </template>
            </el-table-column>
            <el-table-column label="操作">
                <template slot-scope="scope">
                    <el-button @click="scope.row.show =true" >编辑</el-button>
                    <el-button @click="scope.row.show =false">保存</el-button>
                </template>
            </el-table-column>
        </el-table>
      </div> 
</template>
<script>
	export default {
		data(){
    	return {
    	options: [{
          	value: '选项1',
          	stu: '初中'
        	}, {
          	value: '选项2',
          	stu: '高中'
        	}, {
	          value: '选项3',
	          stu: '大专'
	        }, {
	          value: '选项4',
	          stu: '本科'
	        }, {
	          value: '选项5',
	          stu: '博士'
	        }],
	        value: '',
	      tabledatas: [
	                    { name: '李一', age: '19',address:"宁波",stu:"本科",show:false},
	                    { name: '郭明', age: '23',address:"四川",stu:"本科",show:false},
	                    { name: '天天', age: '12',address:"海南",stu:"初中",show:false},
	                    { name: '隆', age: '40',address:"上海",stu:"博士",show:false},
	                ],
	    }
	}
</script>

可以通过设置js里的show:true让该行处于默认编辑状态

出来效果图

vue表头下拉选择框使用总结

1.在el-table-culumn中,加入template标签

使用:

<template slot="header" slot-scope="scope">
  <el-dropdown trigger="click" @command = "handleCommand">
    <span>类型</span>
    <el-dropdown-menu slot="dropdown">
      <el-radio-group v-model="sx">//这里,会出现一个bug,下文有解决办法
        <el-dropdown-item command="属性0"><el-radio label="0">属性0</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性1"><el-radio label="1">属性1</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性2"><el-radio label="2">属性2</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性3"><el-radio label="3">属性3</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性4"><el-radio label="4">属性4</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性5"><el-radio label="5">属性5</el-radio> </el-dropdown-item>
        <el-dropdown-item command="属性6"><el-radio label="6">属性6</el-radio> </el-dropdown-item>
      </el-radio-group>
    </el-dropdown-menu>
  </el-dropdown>
</template>
<template slot-scope="scope">(表中元素)</template>

2.设置handleCommand方法

(当时没使用handleCommand方法做缓冲,在刷新时,第一次刷新不会赋值,第二次刷新会得到上次刷新的值。)

handleCommand(command) {
  if(command == '属性0' ){
    this.sx= '0'
  } else if (command === '属性1') {
    this.sx = '1'
  } else if( command === '属性2') {
    this.sx = '2'
  } else if (command === '属性3') {
    this.sx = '3'
  } else if (command === '属性4') {
    this.sx = '4'
  } else if( command === '属性5') {
    this.sx = '5'
  } else if (command === '属性6') {
    this.sx = '6'
  }
  this.刷新方法;
},

但是在使用过程中,点击下拉框中数据时,会出现执行两次handleCommand()方法的情况。通过一天的询问与查找,得到解决办法。

问题出现在<el-radio>标签上,当点击框中数据时,数据响应一次handleCommand()方法,<el-radio>也会响应一次handleCommand()方法。

所以,应该去掉<el-radio>标签与<el-radio-group>标签。

<template slot="header" slot-scope="scope">
  <el-dropdown trigger="click" @command = "handleCommand">
    <span>类型</span>
    <el-dropdown-menu slot="dropdown">
      <el-dropdown-item command="属性0">属性0</el-dropdown-item>
      <el-dropdown-item command="属性1">属性1</el-dropdown-item>
      <el-dropdown-item command="属性2">属性2</el-dropdown-item>
      <el-dropdown-item command="属性3">属性3</el-dropdown-item>
      <el-dropdown-item command="属性4">属性4</el-dropdown-item>
      <el-dropdown-item command="属性5">属性5</el-dropdown-item>
      <el-dropdown-item command="属性6">属性6</el-dropdown-item>
    </el-dropdown-menu>
  </el-dropdown>
</template>
<template slot-scope="scope">(表中元素)</template>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。 

相关文章

  • Vue.js中让人容易忽略的API详解

    Vue.js中让人容易忽略的API详解

    Vue.js是构建Web界面的渐进式JavaScript框架,通过简洁的 API 提供高效的数据绑定和灵活的组件系统,这篇文章主要给大家介绍了关于Vue.js中让人容易忽略的API的相关资料,需要的朋友可以参考下
    2021-09-09
  • 使用element+vuedraggable实现图片上传拖拽排序

    使用element+vuedraggable实现图片上传拖拽排序

    这篇文章主要为大家详细介绍了使用element+vuedraggable实现图片上传拖拽排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Vue组件引用外部js的实战指南

    Vue组件引用外部js的实战指南

    在Vue.js应用开发中,有时候我们需要在组件内部引入外部JavaScript库或脚本文件来增强组件的功能,本文将详细探讨如何在Vue.js项目中安全有效地引用外部JS文件,并提供一系列示例代码来帮助理解这一过程,需要的朋友可以参考下
    2024-09-09
  • Vue.js directive自定义指令详解

    Vue.js directive自定义指令详解

    这篇文章主要介绍了Vue.js directive自定义指令详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-09-09
  • Vue 中使用vue2-highcharts实现曲线数据展示的方法

    Vue 中使用vue2-highcharts实现曲线数据展示的方法

    下面小编就为大家分享一篇Vue 中使用vue2-highcharts实现曲线数据展示的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • VUE中常用的4种高级方法

    VUE中常用的4种高级方法

    provide/inject 是 Vue.js 中用于跨组件传递数据的一种高级技术,它可以将数据注入到一个组件中,然后让它的所有子孙组件都可以访问到这个数据,这篇文章主要介绍了VUE中常用的4种高级方法,需要的朋友可以参考下
    2023-05-05
  • 如何使用vue3简单实现WebSocket通信

    如何使用vue3简单实现WebSocket通信

    这篇文章主要给大家介绍了关于如何使用vue3简单实现WebSocket通信的相关资料,WebSocket是全双工网络通信通信协议,实现了客户端和服务器的平等对话,任何一方都可以主动发送数据,需要的朋友可以参考下
    2023-08-08
  • 使用Vue3创建多布局系统的三种方法

    使用Vue3创建多布局系统的三种方法

    布局是中大型网站或应用的基础,假设你正在创建一个网页应用,它包括主页、营销页面和应用页面,你不会想要为每一页重复所有的工作,对吧,与Nuxt不同,Vue 3并没有内置的布局系统,但是别担心,这里将向你展示3种简单的方法来实现这一点,需要的朋友可以参考下
    2023-08-08
  • vue项目中引入Sass实例方法

    vue项目中引入Sass实例方法

    在本文里小编给大家整理的是关于vue项目中引入Sass的相关知识点内容,有需要的朋友们可以测试参考下。
    2019-08-08
  • vue使用once修饰符,使事件只能触发一次问题

    vue使用once修饰符,使事件只能触发一次问题

    这篇文章主要介绍了vue使用once修饰符,使事件只能触发一次问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-05-05

最新评论