JavaScript

超轻量级php框架startmvc

vue 封装自定义组件之tabal列表编辑单元格组件实例代码

更新时间:2020-06-03 13:18:01 作者:startmvc
vue封装自定义组件tabal列表编辑单元格组件<template><divclass="editable-cell"><divclass="ed

vue 封装自定义组件

tabal列表编辑单元格组件


<template>
 <div class="editable-cell">
 <div class="editable-cell-input-wrapper" v-if='editable'>
 <el-input class="editInput" v-model="cellValue" placeholder="请输入内容" v-loading="editLoading" size="small"></el-input>
 <el-button type="text"><i class="el-icon-check" @click='check'></i></el-button>
 </div>
 <div class="editable-cell-text-wrapper" v-else>
 {{cellValue || ' '}}
 <el-button type="text"><i class="el-icon-edit" @click='edit'></i></el-button>
 </div>
 </div>
</template>
<script>
import util from '../../common/js/util';
import $ from 'jquery';
import axios from './../../common/ajax/axios.js';
export default { 
 data() {
 return { 
 cellValue:this.value,
 editable:false,
 editLoading:false,
 };
 },
 props : [
 'value'
 ],
 methods: {
 check(){
 const self = this;
 function callback(){
 self.editLoading = false;
 self.editable=false;
 }
 this.editLoading = true;
 self.$emit('cellChange',self.cellValue,callback)
 },
 edit(){
 this.editable = true;
 }
 }
};
</script>

<style lang="less" scoped>
.taskDetail{
 margin-left: 10px;
 margin-top:10px;
}
.editInput{
 width: 200px;
 height: 30px;
}
.el-icon-edit{
 margin-left: 20px;
}
.el-icon-check{
 margin-left: 20px;
}
</style>
<style>
.editInput .el-loading-spinner .circular{
 width:20px;
}
</style>

这里写图片描述

解释一下:

props:父组件传递给子组件的值;

$emit(‘方法名',数据) 返回父级数据,会触发父组件中调用子组件的方法;

父组件中的使用方法:

这里写图片描述

1.先将组件import 进来;

2.然后将组件暴露出去,这样父组件就可以用了;

这里写图片描述

总结

以上所述是小编给大家介绍的vue 封装自定义组件tabal列表编辑单元格组件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

vue tab列表编辑单元格 vue 自定义组件 vue tab 组件