elementUI的动态tabs页的使用,vue的动态组件的操作

有时候我们需要用到动态的tab页,结合不同的页面内容来显示。这里是使用了elementUI的动态tabs页来实现的

<div class="right" v-loading="loading">
<div class="between main-top">
<span @click="addTab(editableTabsValue,'groupInfo(组件的名称)','tabs页的名称')">add tabs</span>
</div>
<el-tabs v-model="editableTabsValue" type="card" @tab-remove="removeTab">
<el-tab-pane v-for="(item, index) in editableTabs" :key="index" :label="item.title" :name="item.name" :closable='item.closable'>
<component :is='item.content' :objId='objId' @fatherEvent="btnclick" @delTab='delTabs'></component>
<!--
:closable='item.closable' ----通过closable来判断当前tabs是否可以关闭
component:通过使用component元素,在根据组件中的is属性来动态的切换不同的组件。
:is='item.content':这是动态绑定的组件
:objId='objId' ----这个是组件之间的传值,父组件传值给子组件的
@fatherEvent="btnclick" ----这是子组件对父组件的操作
@delTab='delTabs' ----这是子组件对父组件的操作
-->
</el-tab-pane>
</el-tabs>
</div>
//---------------------引入组件的模块
import chat from './chat'
import create from './create'
import statements from './statements'
import groupInfo from './groupInfo'
import renew from './renew'
import project from './project'
export default {
props: {},
components: {
chat,
statementsGnode,
createGnode,
groupInfo,
renewGnode,
project
},
data() {
return {
editableTabsValue: '1',
editableTabs: [{//第一个默认打开的tabs
title: '项目通讯',//tabs页的名称
name: '1',
content: chat,//对应组件名称
closable:false// 是否可以关闭,false是不可以,true是可以关闭
}],
tabIndex: 1,
//动态子组件
objId:'',
};
},
addTab(targetName,name,title) {//----------------这是添加tabs页的方法,三个值对应着上面点击方法传过来的,但是也不是三个都要,第一个值是必须要传的
let newTabName = ++this.tabIndex + '';
if (name === 'statements') {//------------------这几个判断是我要区分开不同的组件所需要的值来做的
this.objId = title
this.editableTabs.push({
title: title.name,
name: newTabName,
content: name,
closable:true
});
} else if (name === 'renew'){
this.objId = title
this.editableTabs.push({
title: '够着'+title.name,
name: newTabName,
content: name,
closable:true
});
}else{
this.editableTabs.push({
title: title,
name: newTabName,
content: name,
closable:true
});
} this.editableTabsValue = newTabName;
},
removeTab(targetName) {//--------------这是关闭tab页的
let tabs = this.editableTabs;
let activeName = this.editableTabsValue;
if (activeName === targetName) {
tabs.forEach((tab, index) => {
if (tab.name === targetName) {
let nextTab = tabs[index + 1] || tabs[index - 1];
if (nextTab) {
activeName = nextTab.name;
}
}
});
}
this.editableTabsValue = activeName;
this.editableTabs = tabs.filter(tab => tab.name !== targetName);
},
btnclick(com,item){//这个子组件点击控制父组件的方法,不同的子组件对应不同的调用
if (com === "groupInfo") {
this.ChatMamList();
} else if(com === 'renewGnode'){
let value = this.editableTabsValue
this.addTab(value,com,item)
}else{
this.manageNode();
}
},
delTabs(targetName){ //---------------这是子组件想要关闭当前tab页的,控制父组件的操作
let tabs = this.editableTabs;
let activeName;
tabs.forEach((tab, index) => {
if (tab.title === targetName) { //因为判断不一样
let nextTab = tabs[index + 1] || tabs[index - 1];
if (nextTab) {
activeName = nextTab.name;
}
}
});
this.editableTabsValue = activeName;
this.editableTabs = tabs.filter(tab => tab.title !== targetName);
this.manageNode();
},

以上是父组件的的代码

下面是子组件的代码

props: {
objId:{//----------------接受父组件的值
type:Object
}
},
renew(){
let objInfo = this.objId
this.Gnodedialog = false
//调用父组件的方法,fatherEvent--是在父组件的的动态组件component上面的方法,注意看上面的代码
//'renew',objInfo,都是传值
this.$emit("fatherEvent",'renew',objInfo)
}

elementUI的动态tabs页的使用,vue的动态组件的操作的更多相关文章

  1. [转] JQuery UI Tabs 动态添加页签,并跳转到新页签

    [From] https://blog.csdn.net/zhangfeng2124/article/details/76672403 需求: 1.tabs默认只有一个页签,但是需要点击某按钮,动态添 ...

  2. Element + Vue I18n动态import加载国际化语言包翻译文件

    需求 项目为多页应用,包含产品a.b.c.d.e,每个产品都有自己的翻译文件.一次加载所有翻译文件是极度不合理的.于是考虑动态加载. 实现 参考官方文档:延迟加载翻译 项目结构 │ ├── dist ...

  3. Vue加载组件、动态加载组件的几种方式

    https://cn.vuejs.org/v2/guide/components.html https://cn.vuejs.org/v2/guide/components-dynamic-async ...

  4. Vue 实现动态路由及登录&404页面跳转控制&页面刷新空白解决方案

    Vue实现动态路由及登录&404页面跳转控制&页面刷新空白解决方案   by:授客 QQ:1033553122   开发环境   Win 10   Vue 2.9.6   node-v ...

  5. vue + element 动态渲染、移除表单并添加验证

    博客地址:https://ainyi.com/66 又接到新需求了吧~~ 背景 在一个大表单里,有可能会出现这种需求,用户可以自己操作动态添加.移除表单,更加个性化的效果. 常见于填写个人信息.附加内 ...

  6. Vue 中动态添加class(使用v-bind:class)

    今天在Vue中动态修改类名,元素的样式就是不改变,类名也没有加上去,里面的问题具体我还是不太清楚,有可能是因为自己不认真,把 :class= 后面的内容的格式给整错了,下面将正确的做法记录一下,便于以 ...

  7. vue中动态加载组件+开发者模式+JS参数值传递和引用传递

    今天写vue里面通过接口反参动态加载组件时候 跟着同学...学习到了 一.先说说vue 内置组件 component 的用法 component组件可以来专门用来进行组件的切换,使用is来绑定你的组件 ...

  8. vue中动态添加div

    知识点:vue中动态添加div节点,点击添加,动态生成div,点击删除,删除对应的div,其中数组的长度是动态改变的,如在from表单中应用,直接在提交方法中,获得list,获取所填的元素即可 效果: ...

  9. 周记4——vue中动态添加图片无效、build上线后background-image路径问题

    又是一个周五,又一周要过去了...很开心,这周遇到了vue中的一个比较常见的坑,网上随便一搜就有了很多解决方案...“幸运”的是,我选了一个带坑的方案...所以我觉得有必要记录一下这个“坑中坑”... ...

随机推荐

  1. Unity CommandBuffer物体轮廓

    1.command buffer具有很高的灵活性,它的作用是预定义一些渲染指令,然后在我们想要执行的时候去执行这些指令(见图1),绿点表示可以在"Forward Rendering Path ...

  2. 设置Centos7中vim与vi编辑器显示行号

    设置Centos7中vim与vi编辑器的行号 步骤一: 输入命令设置: 1.vim ~/.vimrc 或者:(vi ~/.vimrc) 步骤二: 输入命令保存: 1.在其中输入 "set n ...

  3. Go语言实现excel导入无限级菜单结构

    目录 需求 实现 测试 简单例子 复杂例子 需求 最近有一个需求,要实现一个无限级结构的树型菜单,差不多长下面这个样子 我们知道无限级实现思路都是用一个parent_id将各种层级串联起来,顶级的pa ...

  4. 美食vlog如何剪辑?用什么视频制作软件剪辑比较好?

    是不是发现自己拍摄的美食永远没有美食博主拍出来的好看?那么美食vlog如何剪辑?用什么视频制作软件剪辑比较好呢?下面小编就教大家用视频编辑软件会声会影强大的颜色分级功能就能拯救你的美食vlog. 接下 ...

  5. 「LOJ 6287」诗歌

    题面 LOJ 6287 Solution 枚举中间点\(j\),题目即求是否存在\(m\)使\(a[j]-m\)与\(a[j]+m\)分别在\(j\)两侧. 对于\(j\)左侧任意一个点\(i\),都 ...

  6. mongodb 副本集之入门篇

    作者: 凹凸曼-军军 前言:mongodb 因为高性能.高可用性.支持分片等特性,作为非关系型数据库被大家广泛使用.其高可用性主要是体现在 mongodb 的副本集上面(可以简单理解为一主多从的集群) ...

  7. mysql GTID主从复制故障后不停机恢复同步流程

    GTID实现主从复制数据同步 GTID是一个基于原始mysql服务器生成的一个已经被成功执行的全局事务ID,它由服务器ID以及事务ID组成,这个全局事务ID不仅仅在原始服务器上唯一,在所有主从关系的m ...

  8. 在HTML中调用打开摄像头

    1 <img src="imgs/qr.png" alt=""> 2 <video src=""></vide ...

  9. 我与PHP,ULM和Vue.js不得不说的故事(我与PHP白月光的那些事儿之第三年的见异思迁番外篇)

    关于PHP的认知 -----恍惚间眸眼像极了一位故人 第一年遇见,那时的它还稚嫩懵懂.像白纸一样的脸,极容易读懂.于是放荡不羁,不放真心.稍微用心,它便能高兴好久.初识它时它叫C语言,浅尝却不觉其难过 ...

  10. OD断点操作

    原文链接:https://www.cnblogs.com/qiyeboy/p/6815988.html 在做Windows平台软件逆向时,Ollydbg是极其常用的逆向工具,动态调试功能非常强大.在调 ...