Skip to content

指定目标容器

由于我们平时使用的过程中,很多需要拖拽的组件并非我们的直系子元素,所以我们需要指定一个目标容器,来完成拖拽的功能,我们可以通过 target 属性来指定目标容器。

此处我们以第三方组件为例,假设el-table为第三方组件

WARNING

注意:只要您能确保获取到的目标元素是正确的,都可以完成我们的功能,如果您在使用过程中发现目标元素未找到,请检查您所输入的选择器是否正确

ElTable.vue

vue
<template>
  <table>
    <thead>
      <tr>
        <th>Id</th>
        <th>Name</th>
      </tr>
    </thead>
    <tbody class="el-table">
      <tr v-for="item in list" :key="item.name" class="cursor-move">
        <td>{{ item.id }}</td>
        <td>{{ item.name }}</td>
      </tr>
    </tbody>
  </table>
</template>
<script setup lang="ts">
interface Props {
  list: Record<'name' | 'id', string>[]
}
defineProps<Props>()
</script>

组件使用

函数使用

注意事项

使用 function 时请保证组件内只有一个根元素

错误使用

这种用法是错误的,因为它包含多个根元素

vue
<template>
  <!-- ❌ -->
  <div id="my-container">
    <ElTable :list="list"></ElTable>
  </div>
  <div class="flex justify-between">
    <pre class="code-block">{{ text }}</pre>
  </div>
</template>

正确使用

这种方式是正确的,因为它只有一个根元素

vue
<template>
  <!-- ✅ -->
  <div>
    <div id="my-container">
      <ElTable :list="list"></ElTable>
    </div>
    <div class="flex justify-between">
      <pre class="code-block">{{ text }}</pre>
    </div>
  </div>
</template>