index.vue 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <template>
  2. <div class="drag-container">
  3. <el-card shadow="hover" header="拖动指令效果(v-drag)作用于 Dialog 对话框">
  4. <el-button type="primary" @click="dialogVisible = true" size="default">
  5. <el-icon>
  6. <ele-Pointer />
  7. </el-icon>
  8. 点击打开 Dialog
  9. </el-button>
  10. </el-card>
  11. <el-card shadow="hover" header="自定义div" class="mt15">
  12. <div class="drag-dom">
  13. <div class="drag-header">
  14. <el-button type="success" size="default" v-drag="['.drag-container .drag-dom', '.drag-container .drag-header']">
  15. <el-icon>
  16. <ele-Pointer />
  17. </el-icon>
  18. 按住进行拖动测试
  19. </el-button>
  20. </div>
  21. </div>
  22. </el-card>
  23. <el-dialog v-model="dialogVisible" width="769px">
  24. <template #title>
  25. <div v-drag="['.drag-container .el-dialog', '.drag-container .el-dialog__header']">拖动指令效果(v-drag)</div>
  26. </template>
  27. <p>鼠标放标题头进行 Dialog 对话框拖动</p>
  28. <template #footer>
  29. <span class="dialog-footer">
  30. <el-button @click="dialogVisible = false" size="default">取 消</el-button>
  31. <el-button type="primary" @click="dialogVisible = false" size="default">确 定</el-button>
  32. </span>
  33. </template>
  34. </el-dialog>
  35. </div>
  36. </template>
  37. <script lang="ts">
  38. import { toRefs, reactive, defineComponent } from 'vue';
  39. export default defineComponent({
  40. name: 'pagesDrag',
  41. setup() {
  42. const state = reactive({
  43. dialogVisible: false,
  44. });
  45. return {
  46. ...toRefs(state),
  47. };
  48. },
  49. });
  50. </script>
  51. <style scoped lang="scss">
  52. .drag-container {
  53. .drag-dom {
  54. position: relative;
  55. display: inline-block;
  56. .drag-header {
  57. display: inline-block;
  58. }
  59. }
  60. }
  61. </style>