可拖动元素必须有一个项目槽

问题描述 投票:0回答:2

我试图在我的笔记本应用程序中使用 vuedraggable,当我添加可拖动组件时出现此错误。这是代码和错误。我将不胜感激的帮助。

这是我收到的错误消息。

错误:可拖动元素必须有一个项目槽 在computeNodes(webpack-internal:///./node_modules/vuedraggable/dist/vuedraggable.umd.js:4483:11) 在computeComponentStructure处(webpack-internal:///./node_modules/vuedraggable/dist/vuedraggable.umd.js:4525:15) 在 Proxy.render (webpack-internal:///./node_modules/vuedraggable/dist/vuedraggable.umd.js:4644:32) 在 renderComponentRoot (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:965:44) 在 componentEffect (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:4382:53) 在reactiveEffect(webpack-internal:///./node_modules/@vue/reactivity/dist/reactivity.esm-bundler.js:71:24) 生效(webpack-internal:///./node_modules/@vue/reactivity/dist/reactivity.esm-bundler.js:46:9) 在 setupRenderEffect (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:4365:89) 在 mountComponent (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:4324:9) 在 processComponent (webpack-internal:///./node_modules/@vue/runtime-core/dist/runtime-core.esm-bundler.js:4284:17)

我没有在 app.vue 上使用 vuedraggable 组件,而是将其作为我的 todo.vue 文件中的组件传递。

任何帮助都会很棒。谢谢你

vue.js vue-component vuedraggable
2个回答
18
投票

只需将您的项目放在

<template #item>
标签中,该错误告诉您,
draggeable
组件内部必须始终有一个名为
item
的插槽。

在 Vue 3 中,您可以使用

#{slotName}

将模板分配给插槽

检查文档中的this演示

示例:

<draggable
      :list="list"
      :disabled="!enabled"
      item-key="name"
      class="list-group"
      ghost-class="ghost"
      :move="checkMove"
      @start="dragging = true"
      @end="dragging = false"
    >
      <template #item="{ element }">
        <div class="list-group-item" :class="{ 'not-draggable': !enabled }">
          {{ element.name }}
        </div>
      </template>
</draggable>

1
投票

如果您使用的是 Vue3 和/或您有嵌套组件,那么您可以按如下方式实现它。

应用程序.vue

<draggable v-model="bookmarks" ghost-class="ghost" group="people" @start="drag=true" @end="dragEnded" :move="checkMove" item-key="id">
  <template #item="{element}">
    <bookmark-card :bookmark="element">
    </bookmark-card>
  </template>
</draggable>

关键部分是添加

<bookmark-card :bookmark="element">
作为:书签投射到组件中。

然后它可以在组件内部使用:

BookmarkCard.vue

<template>
  <li class="p-2 mb-3 m-1.5 flex items-center bg-gray-900 shadow rounded-lg single-bookmark hover:bg-green-500">
      <div class="items-center">
          <button @click="editBookmark" type="button" class="bookmark-edit h-6 w-6 text-white bg-green-700 dark:hover:bg-green-800 font-medium rounded-lg text-sm text-center dark:bg-green-600 dark:hover:bg-gray-600">
            <svg class="w-4 h-4 dark:text-white m-2" fill="none" stroke="currentColor" stroke-width="1.5" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg" aria-hidden="true">
              <path stroke-linecap="round" stroke-linejoin="round" d="M9.594 3.94c.09-.542.56-.94 1.11-.94h2.593c.55 0 1.02.398 1.11.94l.213 1.281c.063.374.313.686.645.87.074.04.147.083.22.127.324.196.72.257 1.075.124l1.217-.456a1.125 1.125 0 011.37.49l1.296 2.247a1.125 1.125 0 01-.26 1.431l-1.003.827c-.293.24-.438.613-.431.992a6.759 6.759 0 010 .255c-.007.378.138.75.43.99l1.005.828c.424.35.534.954.26 1.43l-1.298 2.247a1.125 1.125 0 01-1.369.491l-1.217-.456c-.355-.133-.75-.072-1.076.124a6.57 6.57 0 01-.22.128c-.331.183-.581.495-.644.869l-.213 1.28c-.09.543-.56.941-1.11.941h-2.594c-.55 0-1.02-.398-1.11-.94l-.213-1.281c-.062-.374-.312-.686-.644-.87a6.52 6.52 0 01-.22-.127c-.325-.196-.72-.257-1.076-.124l-1.217.456a1.125 1.125 0 01-1.369-.49l-1.297-2.247a1.125 1.125 0 01.26-1.431l1.004-.827c.292-.24.437-.613.43-.992a6.932 6.932 0 010-.255c.007-.378-.138-.75-.43-.99l-1.004-.828a1.125 1.125 0 01-.26-1.43l1.297-2.247a1.125 1.125 0 011.37-.491l1.216.456c.356.133.751.072 1.076-.124.072-.044.146-.087.22-.128.332-.183.582-.495.644-.869l.214-1.281z"></path>
              <path stroke-linecap="round" stroke-linejoin="round" d="M15 12a3 3 0 11-6 0 3 3 0 016 0z"></path>
            </svg>
          </button>
          <span class="absolute text-white font-small text-sm">{{ bookmark.bookmark_name}}</span>
        </div>
    </li>
</template>
<script>
import Avatar from "vue3-avatar";
export default {
  components: {
    Avatar,
  },
  props: {
    bookmark: {
      type: Object,
      default: () => ({})
    }
  },
  methods: {
    editBookmark() {
      //  To exit draggable component and reach App.vue parent method, add $parent.$parent twice
      this.$parent.$parent.editBookmarkParent(this.bookmark);
    },
  }
}
</script>

© www.soinside.com 2019 - 2024. All rights reserved.