我已经阅读了我能找到的所有文档和stackoverflow,但仍然有问题。
我正在用Vue和Rails构建一个Trello克隆。
我有很多可拖拽的列表。
每个列表都有可拖拽的卡片。
当我将一张卡片从一个列表拖到另一个列表时,如何将其持久化到ajax rails端点?
我尝试过使用@end
方法和:move
属性,但一无所获。
#app.vue
<template>
<draggable v-model="lists" group='lists' class="row dragArea" @end="listMoved">
<div v-for="(list, index) in lists" class="col-3">
<h6>{{ list.name }}</h6>
<hr />
<draggable v-model="list.cards" group='cards' class="dragArea" :move="cardMoved">
<div v-for="(card, index) in list.cards" class="card card-body mb-3">
{{ card.name }}
</div>
</draggable>
<div class="card card-body">
<input v-model="messages[list.id]" class="form-control" ></input>
<button v-on:click="submitMessages(list.id)" class="btn btn-secondary">Add</button>
</div>
</div>
</draggable>
</template>
<script>
import draggable from 'vuedraggable'
export default {
components: { draggable },
props: ["original_lists"],
data: function() {
return {
messages: {},
lists: this.original_lists
}
},
methods: {
cardMoved: function(event) {
console.log(event)
var data = new FormData
data.append("card[list_id]", WHERE_DO_I_FIND_THIS_ID)
data.append("card[position]", event.draggedContext.element.id)
Rails.ajax({
url: `/cards/${event.draggedContext.element.id}/move`,
type: "PATCH",
data: data,
datatype: "json"
})
},
}
}
</script>
发布于 2019-05-04 17:12:36
使用包含所需的所有免打扰信息且仅在拖动操作结束后才会调用的change event。
根据@sovalina的建议,您需要传递链接到列表的额外信息:
:change="changed(list.id, $event)"
同样你的div也应该是键控的:
<div v-for="(card, index) in list.cards" :key="card.name" class="card card-body mb-3">
https://stackoverflow.com/questions/55964002
复制相似问题