feat: 支持 overflow 配置以允许拖拽超出可视区

pull/340/MERGE
dullathanol 2026-04-07 11:41:39 +08:00
parent ad7ed50b52
commit 4e4ffc439c
5 changed files with 15 additions and 3 deletions

View File

@ -34,7 +34,7 @@ Modal 内的内容一般业务中,会比较复杂,所以我们可以将 moda
## 开启拖拽 ## 开启拖拽
通过 `draggable` 参数,可开启拖拽功能。 通过 `draggable` 参数,可开启拖拽功能。若需要拖动范围超出可视区,可设置 `overflow: true`(需已开启 `draggable`)。
<DemoPreview dir="demos/vben-modal/draggable" /> <DemoPreview dir="demos/vben-modal/draggable" />
@ -101,6 +101,7 @@ const [Modal, modalApi] = useVbenModal({
| fullscreen | 全屏显示 | `boolean` | `false` | | fullscreen | 全屏显示 | `boolean` | `false` |
| fullscreenButton | 显示全屏按钮 | `boolean` | `true` | | fullscreenButton | 显示全屏按钮 | `boolean` | `true` |
| draggable | 可拖拽 | `boolean` | `false` | | draggable | 可拖拽 | `boolean` | `false` |
| overflow | 拖动范围可以超出可视区 | `boolean` | `false` |
| closable | 显示关闭按钮 | `boolean` | `true` | | closable | 显示关闭按钮 | `boolean` | `true` |
| centered | 居中显示 | `boolean` | `false` | | centered | 居中显示 | `boolean` | `false` |
| modal | 显示遮罩 | `boolean` | `true` | | modal | 显示遮罩 | `boolean` | `true` |

View File

@ -46,6 +46,7 @@ export class ModalApi {
contentClass: '', contentClass: '',
destroyOnClose: true, destroyOnClose: true,
draggable: false, draggable: false,
overflow: false,
footer: true, footer: true,
footerClass: '', footerClass: '',
fullscreen: false, fullscreen: false,

View File

@ -110,6 +110,11 @@ export interface ModalProps {
* *
*/ */
openAutoFocus?: boolean; openAutoFocus?: boolean;
/**
*
* @default false
*/
overflow?: boolean;
/** /**
* *
*/ */

View File

@ -81,6 +81,7 @@ const {
description, description,
destroyOnClose, destroyOnClose,
draggable, draggable,
overflow,
footer: showFooter, footer: showFooter,
footerClass, footerClass,
fullscreen, fullscreen,
@ -122,6 +123,7 @@ const { dragging, transform } = useModalDraggable(
shouldDraggable, shouldDraggable,
getAppendTo, getAppendTo,
shouldCentered, shouldCentered,
overflow,
); );
const firstOpened = ref(false); const firstOpened = ref(false);

View File

@ -15,6 +15,7 @@ export function useModalDraggable(
draggable: ComputedRef<boolean>, draggable: ComputedRef<boolean>,
containerSelector?: ComputedRef<string | undefined>, containerSelector?: ComputedRef<string | undefined>,
centered?: ComputedRef<boolean>, centered?: ComputedRef<boolean>,
overflow?: ComputedRef<boolean>,
) { ) {
const transform = reactive({ const transform = reactive({
offsetX: 0, offsetX: 0,
@ -67,8 +68,10 @@ export function useModalDraggable(
let moveX = offsetX + e.clientX - downX; let moveX = offsetX + e.clientX - downX;
let moveY = offsetY + e.clientY - downY; let moveY = offsetY + e.clientY - downY;
moveX = Math.min(Math.max(moveX, minLeft), maxLeft); if (!overflow?.value) {
moveY = Math.min(Math.max(moveY, minTop), maxTop); moveX = Math.min(Math.max(moveX, minLeft), maxLeft);
moveY = Math.min(Math.max(moveY, minTop), maxTop);
}
transform.offsetX = moveX; transform.offsetX = moveX;
transform.offsetY = moveY; transform.offsetY = moveY;