vue 封装自定义组件之tabal列表编辑单元格组件实例代码
程序员文章站
2022-04-28 23:47:25
vue 封装自定义组件
tabal列表编辑单元格组件
...
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列表编辑单元格组件,希望对大家有所帮助