UNPKG

cloud-ui.vusion

Version:
302 lines (276 loc) 8.26 kB
### 基本用法 将需要弹出的内容用`<m-popper>`包裹起来,并插入到触发事件的元素中。 ``` html <u-button> click <m-popper> <u-block>popper</u-block> </m-popper> </u-button> ``` ### 触发方式 使用`trigger`属性设置触发方式。 #### 自动触发 ``` html <u-linear-layout> <u-button> click(默认) <m-popper trigger="click"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> hover <m-popper trigger="hover"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> right-click <m-popper trigger="right-click"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> double-click <m-popper trigger="double-click"> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> ``` #### 手动触发 也可以手动触发弹出层的弹出/关闭: ``` vue <template> <u-button @click="opened = !opened"> {{ opened ? '隐藏' : '弹出' }} <m-popper trigger="manual" :opened.sync="opened"> <u-block>popper</u-block> </m-popper> </u-button> </template> <script> export default { data() { return { opened: false, }; }, }; </script> ``` #### 显隐延时 使用`hover-delay`属性和`hide-delay`属性控制显隐的延时。 ``` html <u-button> hover <m-popper trigger="hover" :hover-delay="200" :hide-delay="1000"> <u-block>popper</u-block> </m-popper> </u-button> ``` ### 弹出方位 使用`placement`属性控制弹出方位。 ``` html <u-linear-layout direction="vertical" style="min-width: 300px; max-width: 550px;"> <u-linear-layout justify="center" gap="small"> <u-button> 上左 <m-popper placement="top-start"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 上边 <m-popper placement="top"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 上右 <m-popper placement="top-end"> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout direction="vertical" justify="center" style="width: 150px; float: left"> <u-button> 左上 <m-popper placement="left-start"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 左边 <m-popper placement="left"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 左下 <m-popper placement="left-end"> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout direction="vertical" justify="center" style="width: 150px; float: right"> <u-button> 右上 <m-popper placement="right-start"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 右边 <m-popper placement="right"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 右下 <m-popper placement="right-end"> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout justify="center" gap="small" style="clear: both;"> <u-button> 下左 <m-popper placement="bottom-start"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 下边 <m-popper placement="bottom"> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 下右 <m-popper placement="bottom-end"> <u-block>popper</u-block> </m-popper> </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> 上左 <m-popper trigger="hover" placement="top-start" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 上边 <m-popper trigger="hover" placement="top" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 上右 <m-popper trigger="hover" placement="top-end" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout direction="vertical" justify="center" style="width: 150px; float: left"> <u-button> 左上 <m-popper trigger="hover" placement="left-start" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 左边 <m-popper trigger="hover" placement="left" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 左下 <m-popper trigger="hover" placement="left-end" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout direction="vertical" justify="center" style="width: 150px; float: right"> <u-button> 右上 <m-popper trigger="hover" placement="right-start" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 右边 <m-popper trigger="hover" placement="right" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 右下 <m-popper trigger="hover" placement="right-end" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout justify="center" gap="small" style="clear: both"> <u-button> 下左 <m-popper trigger="hover" placement="bottom-start" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 下边 <m-popper trigger="hover" placement="bottom" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> <u-button> 下右 <m-popper trigger="hover" placement="bottom-end" follow-cursor> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> <u-linear-layout justify="center"> <u-button> 自定义 <m-popper trigger="hover" placement="bottom-start" :follow-cursor="50"> <u-block>popper</u-block> </m-popper> </u-button> </u-linear-layout> </u-linear-layout> ``` ### 右键菜单 使用`trigger`和`follow-cursor`两个属性可以很容易的实现右键菜单功能。 ``` html <u-button> 右键菜单 <m-popper trigger="right-click" placement="right-start" follow-cursor> <u-menu 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> </m-popper> </u-button> ``` ### 禁用状态 给弹出层添加`disabled`属性可以禁止弹出效果,但需要手动设置外层元素的状态。 ``` html <u-button disabled> disabled <m-popper disabled> <u-block>popper</u-block> </m-popper> </u-button> ```