Vue动态组件表格的实现代码
更新时间:2022年10月16日 11:51:47 作者:生活在北极的企鹅
这篇文章主要介绍了Vue动态组件表格的实现代码,包括框架结构组件,文中还给大家封装了几个组件,有按钮组件、图片组件、滑动开关,结合示例代码给大家详细讲解,需要的朋友可以参考下
Vue组件
数据源
//这里是HTML内容 这里通过下面的引入框架结构把数据源传到框架中 还有匹配项 <Mytable :configList="configList" :configData="configData"></Mytable> // 引入结构组件 import myCard from "./components/card"; // 注册组件 components: { myCard }, data() { return { // 这里定义数据列表 configList: [ // 这里是数据有源 { text: "111", img: "/02.jpg", tap: "标签1", switch: true, button: "按钮1", }, ], // 这里定义匹配项 configData: [ { table: "货币", porp: "text", name: "MyText", }, { table: "图片", porp: "img", name: "Myimg", }, { table: "标签", porp: "tap", name: "tag", }, { table: "滑动开关", porp: "switch", name: "Btn", funName: (row) => { this.mySwitch(row); }, }, { table: "按钮", porp: "button", name: "Mybtn", // 如果组件中需要动态绑定事件 在这里设置 funName: (row) => { this.myBtn(row); }, }, ] } ]
框架结构组件
<div> // 这里接受数据组件传递过来的数据 <el-table :data="configList"> <!-- 文字表格区间 --> // 这里进行循环渲染数据 <el-table-column align="center" v-for="(item, index) in configData" :key="index" :label="item.table" > <!-- 组件 --> // 动态组件 这里可以进行标签 按钮 图片等 的别的组件进行循环渲染到表格中 <template slot-scope="scope"> <component :is="item.name" :value="scope.row" // 把每一项有点击事件进行传参 @parentFun="fun(item.funName, scope.row)" ></component> </template> </el-table-column> </el-table> </div> // 这里引用自己封装的动态组件 import Myimg from "@/components/toConfigure/img.vue"; import tag from "@/components/toConfigure/tag.vue"; import Btn from "@/components/toConfigure/switch.vue"; import MyText from "@/components/toConfigure/text.vue"; import Mybtn from "@/components/toConfigure/button.vue"; // 进行注册组件 components: { Myimg, tag, Btn, MyText, Mybtn, }, // 这里进行判断每个按钮时候有点击事件 没有为空 methods: { fun(funName, row) { if (funName) { funName(row); } }, }, // 这里接受传过来的数据 props: { configData: { type: Array, }, configList: { type: Array, }, },
这里我自己封装了几个组件
按钮组件
<template> // 这里是按钮 <el-button round @click="btn">{{ value.button }}</el-button> </template> <script> export default { // 接受组件传过来的值 props: { value: { type: Object, }, }, // 这里进行绑定动态点击事件 methods: { btn() { // 这里接受传参 this.$emit("parentFun"); }, }, }; </script> <style></style>
图片组件
<template> <div> <el-image style="width: 100px; height: 100px" :src="Myimg" // 使用时候把这条注释删除 这个属性是点击图片放大 不需要可以删除 :preview-src-list="[Myimg]" ></el-image> </div> </template> <script> export default { props: { value: { type: Object, }, }, computed: { Myimg() { if (this.value.img.length > 0) { // "@/assets/images" 这个是图片的根路径 加上 传递过来的数据中图片的名字 return require("@/assets/images" + this.value.img); } else { return; } }, }, }; </script> <style></style>
滑动开关
<template> <div> <el-switch v-if="this.value.switch !== undefined" v-model="value.switch" active-color="#13ce66" inactive-color="#ff4949" @change="switchClick" ></el-switch> </div> </template> <script> export default { props: { value: { type: Object, }, }, methods: { switchClick() { // 事件分发 this.$emit("parentFun", this.value); }, }, mounted() { // console.log(this.value.button); }, }; </script> <style></style>
tap组件
<template> <div> <el-tag v-if="value.tap.length > 0">{{ value.tap }}</el-tag> </div> </template> <script> export default { props: { value: { type: Object, }, }, }; </script> <style></style>
text组件
<template> <div> {{ value.text }} </div> </template> <script> export default { props: { value: { type: Object, }, }, }; </script> <style></style>
到此这篇关于Vue动态组件 表格的文章就介绍到这了,更多相关Vue动态组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue axios form-data格式传输数据和文件方式
这篇文章主要介绍了vue axios form-data格式传输数据和文件方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-05-05一文教会你搭建vite项目并配置路由和element-plus
由于项目搭建过程实在繁琐,容易遗忘,每次新建项目还得百度一下怎么搭建,所以写下本文提醒自己,下面这篇文章主要给大家介绍了关于搭建vite项目并配置路由和element-plus的相关资料,需要的朋友可以参考下2022-07-07
最新评论