cloud-ui.vusion
Version:
Vusion Cloud UI
107 lines (97 loc) • 3.72 kB
Markdown
### 基本用法
#### Tag 方式
``` vue
<template>
<u-tree-select v-model="value" :data-source="load" text-field="title" value-field="title">
</u-tree-select>
</template>
<script>
// 模拟后端请求
const mockRequest = (data, timeout = 300) => new Promise((res, rej) => setTimeout(() => res(data), timeout));
export default {
data() {
return {
value: '页面2'
};
},
methods: {
load(params) {
if (!params.node) {
return mockRequest([
{ type: 'app', title: '应用1', childrenField: 'services' },
{ type: 'app', title: '应用2', childrenField: 'services' },
]);
} else if (params.node.type === 'app') {
return mockRequest([
{ type: 'service', title: '服务1', childrenField: 'pages' },
{ type: 'service', title: '服务2', childrenField: 'pages' },
{ type: 'service', title: '服务3', childrenField: 'pages' },
]);
} else if (params.node.type === 'service') {
return mockRequest([
{ type: 'page', title: '页面1', isLeaf: true, childrenField: 'children' },
{ type: 'page', title: '页面2', isLeaf: true, childrenField: 'children' },
]);
}
},
},
}
</script>
```
#### Tag 方式
``` html
<u-tree-select value="节点 1" valueField="text" textField="text1">
<u-tree-view-node text="节点 1" :node="{text1: '节点 2'}">
<u-tree-view-node text="节点 1.1" :node="{text1: '节点 1.1'}"></u-tree-view-node>
<u-tree-view-node text="节点 1.2" :node="{text1: '节点 1.2'}">
<u-tree-view-node text="节点 1.2.1" :node="{text1: '节点 1.2.1'}"></u-tree-view-node>
<u-tree-view-node text="节点 1.2.2" :node="{text1: '节点 1.2.2'}"></u-tree-view-node>
</u-tree-view-node>
<u-tree-view-node text="节点 1.3" :node="{text1: '节点 1.3'}"></u-tree-view-node>
<u-tree-view-node text="节点 1.4" :node="{text1: '节点 1.4'}"></u-tree-view-node>
</u-tree-view-node>
<u-tree-view-node text="节点 2" :node="{text1: '节点 2'}"></u-tree-view-node>
<u-tree-view-node text="节点 3" :node="{text1: '节点 3'}">
<u-tree-view-node text="节点 3.1" :node="{text1: '节点 3.1'}"></u-tree-view-node>
<u-tree-view-node text="节点 3.2" :node="{text1: '节点 3.2'}"></u-tree-view-node>
</u-tree-view-node>
</u-tree-select>
```
#### Data 方式
``` html { width: 30% }
<u-tree-select value="节点 1" valueField="text1" textField="text1" :data="[
{ text1: '节点 1', children: [
{ text1: '节点 1.1' },
{ text1: '节点 1.2', children: [
{ text1: '节点 1.2.1' },
{ text1: '节点 1.2.2' },
] },
{ text1: '节点 1.3' },
{ text1: '节点 1.4' },
] },
{ text1: '节点 2' },
{ text1: '节点 3', children: [
{ text1: '节点 3.1' },
{ text1: '节点 3.2' },
] },
]"></u-tree-select>
```
#### 支持多选
``` html { width: 30% }
<u-tree-select value="节点 1" checkable valueField="text1" textField="text1" :data="[
{ text1: '节点 1', children: [
{ text1: '节点 1.1' },
{ text1: '节点 1.2', children: [
{ text1: '节点 1.2.1' },
{ text1: '节点 1.2.2' },
] },
{ text1: '节点 1.3' },
{ text1: '节点 1.4' },
] },
{ text1: '节点 2' },
{ text1: '节点 3', children: [
{ text1: '节点 3.1' },
{ text1: '节点 3.2' },
] },
]"></u-tree-select>
```