之前在使用Element-ui的tabs标签页的时候,content内容只能是html内容和字符串,所以在使用element自定义标签(比如按钮<el-button>,表格<el-table>)的时候会出现直接显示字符串的样子,对于第二种方案,会有一个小问题,就是第二个数组移除完的时候,需要自己写一个判断,默认选中上一个数组最后一个tab,
其它说明:我没有搭建vue 脚手架,而是直接在html和jsp页面使用new Vue({})的,请根据自己实际情况做相应更改。
一 第一种方法,通过iframe
<!DOCTYPE html>
<html>
<head>
<title>主页</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- 引入VUE -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
</head>
<body>
<div id="app" >
<div style="margin-bottom: 20px;">
<el-button
size="small"
@click="addTab(editableTabsValue2)"
>
add tab
</el-button>
</div>
<el-tabs v-model="editableTabsValue2" type="card" closable @tab-remove="removeTab">
<el-tab-pane
key="X"
label="名称"
name="X"
>
内容
</el-tab-pane>
<el-tab-pane
v-for="(item, index) in editableTabs2"
:key="item.name"
:label="item.title"
:name="item.name"
>
<iframe :src="item.content" style="width:100%;height:800px;border:none;"></iframe>
</el-tab-pane>
</el-tabs>
</div>
</body>
<script>
var app = new Vue({
el:"#app",
data:{
editableTabsValue2: 'X',
editableTabs2: [],
tabIndex: 2
},methods:{
addTab(targetName) {
let newTabName = ++this.tabIndex + '';
this.editableTabs2.push({
title: 'iframe新建自定义内容',
name: newTabName,
content: 'http://www.baidu.com'
});
this.editableTabsValue2 = newTabName;
}
}
});
</script>
</html>
二 通过自定义组件
<!DOCTYPE html>
<html>
<head>
<title>主页</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- 引入VUE -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
</head>
<body>
<div id="app" >
<div style="margin-bottom: 20px;">
<el-button
size="small"
@click="addTab(editableTabsValue2)"
>
添加自定义内容为test的tab
</el-button>
<el-button
size="small"
@click="addTab2(editableTabsValue2)"
>
添加自定义内容为test2的tab
</el-button>
</div>
<el-tabs v-model="editableTabsValue2" type="card" closable @tab-remove="removeTab">
<el-tab-pane
key="X"
label="名称"
name="X"
>
内容
</el-tab-pane>
<el-tab-pane
v-for="(item, index) in editableTabs2"
:key="item.name"
:label="item.title"
:name="item.name"
>
<test></test>
</el-tab-pane>
<el-tab-pane
v-for="(item, index) in editableTabs3"
:key="item.name"
:label="item.title"
:name="item.name"
>
<test2></test2>
</el-tab-pane>
</el-tabs>
</div>
</body>
<script>
//注册全局组件
//加载特征管理列表
//var htmlobj=$.ajax({url:'../views/feature/featureAdd.html',options:{accept: 'text/html, text/plain'},async:false});
//var html = htmlobj.responseText;
//
//注册一个特征管理列表组件
Vue.component('test', {
data: function () {
return {
form: {
name: ''
}
}
},methods:{
onSubmit:function(){
}
},created:function () {
//组件被创建的时候调用
//如果该组件通过json引入的,那么可以在父页面将数据放到cookie里面,然后在这里获取
//例如 getcookie(id)
//然后就可以使用这个id 初始化data啦
},
//template:html 可通过json获取已经定义好的界面
template:'<el-row><el-button>我是自定义的组件1,我在tabpanel里面哦</el-button></el-row>'//这里我就做一个简单的演示 我真正使用的时候是使用上面那种json获取的组件内容
});
Vue.component('test2', {
data: function () {
return {
form: {
name: ''
}
}
},methods:{
onSubmit:function(){
}
},created:function () {
//组件被创建的时候调用
//如果该组件通过json引入的,那么可以在父页面将数据放到cookie里面,然后在这里获取
//例如 getcookie(id)
//然后就可以使用这个id 初始化data啦
},
//template:html 可通过json获取已经定义好的界面
template:'<el-row><el-button>我是自定义的组件2,我在tabpanel里面哦</el-button></el-row>'//这里我就做一个简单的演示 我真正使用的时候是使用上面那种json获取的组件内容
});
var app = new Vue({
el:"#app",
data:{
editableTabsValue2: 'X',
editableTabs2: [],
editableTabs3: [],
tabIndex: 2
},methods:{
addTab(targetName) {
let newTabName = ++this.tabIndex + '';
//例如 setcookie(id)
this.editableTabs2.push({
title: '新建tab内容为自定义组件1',
name: newTabName,
content: ''
});
this.editableTabsValue2 = newTabName;
},
addTab2(targetName) {
let newTabName = ++this.tabIndex + '';
//例如 setcookie(id)
this.editableTabs3.push({
title: '新建tab内容为自定义组件2',
name: newTabName,
content: ''
});
this.editableTabsValue2 = newTabName;
}
}
});
</script>
</html>
三 最好的方案 也是自定义组件
<!DOCTYPE html>
<html>
<head>
<title>主页</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- 引入VUE -->
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
<!-- 引入样式 -->
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
</head>
<body>
<div id="app" >
<div style="margin-bottom: 20px;">
<el-button
size="small"
@click="addTab(editableTabsValue2)"
>
添加自定义内容tab
</el-button>
</div>
<el-tabs v-model="editableTabsValue2" type="card" closable @tab-remove="removeTab">
<el-tab-pane
:key="item.name"
v-for="(item, index) in editableTabs2"
:label="item.title"
:name="item.name"
>
<!-- 组件会在 `currentTabComponent` 改变时改变 -->
<component v-bind:is="item.content"></component>
</el-tab-pane>
</el-tabs>
</div>
</body>
<script>
//注册全局组件
//加载特征管理列表
//var htmlobj=$.ajax({url:'../views/feature/featureAdd.html',options:{accept: 'text/html, text/plain'},async:false});
//var html = htmlobj.responseText;
//
//注册一个特征管理列表组件
Vue.component('test', {
data: function () {
return {
form: {
name: ''
}
}
},methods:{
onSubmit:function(){
}
},created:function () {
//组件被创建的时候调用
//如果该组件通过json引入的,那么可以在父页面将数据放到cookie里面,然后在这里获取
//例如 getcookie(id)
//然后就可以使用这个id 初始化data啦
},
//template:html 可通过json获取已经定义好的界面 如果有脚手架就更好办啦,直接import然后然道component里面就可以使用啦
template:'<el-row><el-button>内容11111111111111111</el-button></el-row>'//这里我就做一个简单的演示 我真正使用的时候是使用上面那种json获取的组件内容或者import引入
});
Vue.component('test2', {
data: function () {
return {
form: {
name: ''
}
}
},methods:{
onSubmit:function(){
}
},created:function () {
//组件被创建的时候调用
//如果该组件通过json引入的,那么可以在父页面将数据放到cookie里面,然后在这里获取
//例如 getcookie(id)
//然后就可以使用这个id 初始化data啦
},
//template:html 可通过json获取已经定义好的界面 如果有脚手架就更好办啦,直接import然后然道component里面就可以使用啦
template:'<el-row><el-button>内容2222222222222222222</el-button></el-row>'//这里我就做一个简单的演示 我真正使用的时候是使用上面那种json获取的组件内容或者import引入
});
var app = new Vue({
el:"#app",
data:{
editableTabsValue2: 'X',
editableTabs2: [],
tabIndex: 2
},methods:{
addTab(targetName) {
let newTabName = ++this.tabIndex + '';
this.editableTabs2.push({
title: '新建tab内容为自定义组件' + newTabName,
name: newTabName,
content: newTabName%2==0?'test':'test2'
});
this.editableTabsValue2 = newTabName;
}
}
});
</script>
</html>