Files
ncform/packages/ncform-theme-elementui/examples/layout-comps/array-tabs.html
T

187 lines
4.7 KiB
JavaScript
Executable File

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>array-tabs widget</title>
<link rel="stylesheet" href="../demo.css">
<!-- 引入样式 -->
<link rel="stylesheet" href="../../node_modules/element-ui/lib/theme-chalk/index.css">
</head>
<body>
<!--演示区域-->
<div id="demo" v-cloak>
<div v-for="(item, idx) in formSchemas">
<h4 class="demo_title">{{item.title}}</h4>
<div class="demo_item-wrapper">
<div>
<ncform :form-schema="item.schema" v-model="item.schema.value"></ncform>
<small>value: {{item.schema.value}}</small>
</div>
<div>
<pre>{{JSON.stringify(originFormSchemas[idx].schema.properties, null, 2)}}</pre>
</div>
<div>
<pre>{{item.detail}}</pre>
</div>
</div>
</div>
</div>
<script type="text/javascript" src="../../node_modules/lodash/lodash.min.js"></script>
<script type="text/javascript" src="../../node_modules/vue/dist/vue.min.js"></script>
<script type="text/javascript" src="https://unpkg.com/element-ui@2.0.7/lib/index.js"></script>
<script type="text/javascript" src="../../node_modules/@ncform/ncform-common/dist/ncformCommon.min.js"></script>
<script type="text/javascript" src="../../node_modules/@ncform/ncform/dist/vueNcform.js"></script>
<script type="text/javascript" src="../../dist/input.js"></script>
<script type="text/javascript" src="../../dist/object.js"></script>
<script type="text/javascript" src="../../dist/arrayTabs.js"></script>
<script type="text/javascript">
Vue.use(vueNcform, { extComponents: { input: input.default, object: object.default, arrayTabs: arrayTabs.default } });
let formSchemas = [
{
title: '默认状态',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'string'
},
ui: {
widget: 'array-tabs'
}
}
}
}
},
{
title: '[属性] disableAdd: 是否禁止添加项',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'string'
},
ui: {
widget: 'array-tabs',
widgetConfig: {
disableAdd: true
}
}
}
}
}
},
{
title: '[属性] disableDel: 是否禁止删除项',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'string'
},
ui: {
widget: 'array-tabs',
widgetConfig: {
disableDel: true
}
}
}
}
}
},
{
title: '[属性] collapsed: 是否默认折叠',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'string'
},
ui: {
widget: 'array-tabs',
widgetConfig: {
collapsed: true
}
}
}
}
}
},
{
title: '[属性] disableCollapse: 是否禁止折叠',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'string'
},
ui: {
widget: 'array-tabs',
widgetConfig: {
disableCollapse: true
}
}
}
}
}
},
{
title: '[属性] tabPosition: tab的显示位置,可选值 [left | top]',
schema: {
type: 'object',
properties: {
user: {
type: 'array',
items: {
type: 'object',
properties: {
firstname: {
type: 'string'
},
lastname: {
type: 'string'
}
}
},
ui: {
widget: 'array-tabs',
widgetConfig: {
tabPosition: 'left'
}
}
}
}
}
},
]
// Bootstrap the app
new Vue({
el: '#demo',
data: {
formSchemas: _.cloneDeep(formSchemas),
originFormSchemas: formSchemas
}
});
</script>
</body>
</html>