cloud-ui.vusion
Version:
Vusion Cloud UI
275 lines (251 loc) • 8.07 kB
Markdown
### 基本用法
将需要弹出的内容用`<u-popup>`包裹起来,并插入到触发事件的元素中。
``` html
<u-linear-layout>
<u-button>
内容
<u-popup>使用 content 属性添加内容</u-popup>
</u-button>
<u-button>
标题
<u-popup title="标题">使用 title 属性添加标题</u-popup>
</u-button>
<u-button>
使用 slot
<u-popup>
<span slot="title">标题 <u-badge :value="3"></u-badge></span>
<span>使用 <u-link>slot</u-link> 可以添加一些复杂功能</span>
</u-popup>
</u-button>
</u-linear-layout>
```
### 自定义
通过 root 插槽可以自定义整体内容。
``` html
<u-linear-layout>
<u-button>
Dropdown
<u-popup>
<u-menu slot="root" value="3" :router="false">
<u-menu-item value="1">指南</u-menu-item>
<u-menu-item value="2">概念</u-menu-item>
<u-menu-item value="3">组件</u-menu-item>
</u-menu>
</u-popup>
</u-button>
<u-button>
Textarea
<u-popup>
<u-textarea slot="root"></u-textarea>
</u-popup>
</u-button>
<u-button>
TreeView
<u-popup>
<u-tree-view slot="root">
<u-tree-view-node text="节点1">
<u-tree-view-node text="节点1.1"></u-tree-view-node>
<u-tree-view-node text="节点1.2">
<u-tree-view-node text="节点1.2.1"></u-tree-view-node>
<u-tree-view-node text="节点1.2.2"></u-tree-view-node>
</u-tree-view-node>
<u-tree-view-node text="节点1.3"></u-tree-view-node>
<u-tree-view-node text="节点1.4"></u-tree-view-node>
</u-tree-view-node>
<u-tree-view-node text="节点2"></u-tree-view-node>
<u-tree-view-node text="节点3">
<u-tree-view-node text="节点3.1"></u-tree-view-node>
<u-tree-view-node text="节点3.2"></u-tree-view-node>
</u-tree-view-node>
</u-tree-view>
</u-popup>
</u-button>
</u-linear-layout>
```
### 触发方式
使用`trigger`属性设置触发方式。
``` html
<u-linear-layout>
<u-button>
hover
<u-popup trigger="hover">Popup</u-popup>
</u-button>
<u-button>
click(默认)
<u-popup trigger="click">Popup</u-popup>
</u-button>
<u-button>
right-click
<u-popup trigger="right-click">Popup</u-popup>
</u-button>
<u-button>
double-click
<u-popup trigger="double-click">Popup</u-popup>
</u-button>
</u-linear-layout>
```
#### 手动触发
也可以手动触发弹出框的弹出/关闭:
``` vue
<template>
<u-button @click="opened = !opened">
{{ opened ? '隐藏' : '弹出' }}
<u-popup trigger="manual" :opened.sync="opened">Popup</u-popup>
</u-button>
</template>
<script>
export default {
data() {
return {
opened: false,
};
},
};
</script>
```
### 弹出方位
使用`placement`属性控制弹出方位。
``` html
<u-linear-layout direction="vertical" style="min-width: 300px; max-width: 550px;">
<u-linear-layout justify="center" gap="small">
<u-button>
上左
<u-popup placement="top-start">Popup</u-popup>
</u-button>
<u-button>
上边
<u-popup placement="top">Popup</u-popup>
</u-button>
<u-button>
上右
<u-popup placement="top-end">Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout direction="vertical" justify="center" style="width: 150px; float: left">
<u-button>
左上
<u-popup placement="left-start">Popup</u-popup>
</u-button>
<u-button>
左边
<u-popup placement="left">Popup</u-popup>
</u-button>
<u-button>
左下
<u-popup placement="left-end">Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout direction="vertical" justify="center" style="width: 150px; float: right">
<u-button>
右上
<u-popup placement="right-start">Popup</u-popup>
</u-button>
<u-button>
右边
<u-popup placement="right">Popup</u-popup>
</u-button>
<u-button>
右下
<u-popup placement="right-end">Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout justify="center" gap="small" style="clear: both;">
<u-button>
下左
<u-popup placement="bottom-start">Popup</u-popup>
</u-button>
<u-button>
下边
<u-popup placement="bottom">Popup</u-popup>
</u-button>
<u-button>
下右
<u-popup placement="bottom-end">Popup</u-popup>
</u-button>
</u-linear-layout>
</u-linear-layout>
```
#### 跟随鼠标
开启`follow-cursor`属性可以让弹出层跟随鼠标。也可以传一个数字或对象调整位置偏移。
``` html
<u-linear-layout direction="vertical" style="min-width: 300px; max-width: 550px;">
<u-linear-layout justify="center" gap="small">
<u-button>
上左
<u-popup placement="top-start" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
上边
<u-popup placement="top" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
上右
<u-popup placement="top-end" follow-cursor>Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout direction="vertical" justify="center" style="width: 150px; float: left">
<u-button>
左上
<u-popup placement="left-start" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
左边
<u-popup placement="left" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
左下
<u-popup placement="left-end" follow-cursor>Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout direction="vertical" justify="center" style="width: 150px; float: right">
<u-button>
右上
<u-popup placement="right-start" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
右边
<u-popup placement="right" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
右下
<u-popup placement="right-end" follow-cursor>Popup</u-popup>
</u-button>
</u-linear-layout>
<u-linear-layout justify="center" gap="small" style="clear: both;">
<u-button>
下左
<u-popup placement="bottom-start" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
下边
<u-popup placement="bottom" follow-cursor>Popup</u-popup>
</u-button>
<u-button>
下右
<u-popup placement="bottom-end" follow-cursor>Popup</u-popup>
</u-button>
</u-linear-layout>
</u-linear-layout>
```
### 右键菜单
使用`trigger`和`follow-cursor`两个属性可以很容易的实现右键菜单功能。
``` html
<u-button>
右键菜单
<u-popup trigger="right-click" placement="right-start" follow-cursor>
<u-menu slot="root" value="3" :router="false">
<u-menu-item value="1">指南</u-menu-item>
<u-menu-item value="2">概念</u-menu-item>
<u-menu-item value="3">组件</u-menu-item>
</u-menu>
</u-popup>
</u-button>
```
### 禁用状态
给弹出框添加`disabled`属性可以禁止弹出效果,但需要手动设置外层元素的状态。
``` html
<u-button disabled>
disabled
<u-popup disabled>Popup</u-popup>
</u-button>
```