Vue可拖动的限制列表到1个元素

时间:2020-01-31 22:20:40

标签: vue.js jquery-ui-draggable sortablejs vuedraggable

在这里,我试图从排名列表中克隆元素并将其放入两个列表(list1和list2)中的任何一个中。一切似乎都正常,我可以拖放,但由于两个列表均未受影响,因此绑定似乎不起作用,因为当我将元素拖动到列表中时,观察程序不会运行。另外,克隆功能不会将消息打印到控制台。我以this example作为参考。

<template>
  <div>
    <div>
      <div>
        <draggable
          @change="handleChange"
          :list="list1"
          :group="{ name: 'fighter', pull: false, put: true }"
        ></draggable>
      </div>
      <div>
        <draggable 
          @change="handleChange"
          :list="list2" 
          :group="{ name: 'fighter', pull: false, put: true }
        ></draggable>
      </div>
    </div>
    <div>
      <div v-for="wc in rankings" :key="wc.wclass">
        <Card>
          <draggable :clone="clone" 
                     :group="{ name: 'fighter', pull: 'clone', put: false }"
          >
            <div class="cell" v-for="(fighter, idx) in wc.fighters" :key="fighter[0]">
                <div class="ranking">
                  {{ idx + 1 }}
                </div>
                <div class="name">
                  {{ fighter[0] }}
                </div>
            </div>
          </draggable>
        </Card>
      </div>
    </div>
  </div>
</template>

<script>
import axios from "axios";
import draggable from "vuedraggable";

export default {
  components: {
    draggable
  },
  data() {
    return {
      rankings: [],
      list1: [],
      list2: []
    };
  },
  methods: {
    getRankingLabel(label) {
      if (!label || label == "NR") return 0;
      if (label.split(" ").indexOf("increased") !== -1) return 1;
      if (label.split(" ").indexOf("decreased") !== -1) return -1;
    },
    clone({ id }) {
      console.log("cloning");
      return {
        id: id + "-clone",
        name: id
      };
    },
    handleChange(event) {
      console.log(event);
    }
  },
  watch: { 
    // here I am keeping the length of both lists at 1  
    list1: function(val) {
      console.log(val); // nothing prints, as the watcher does not run
      if (val.length > 1) {
        this.fighter_one.pop();
      }
    },
    list2: function(val) {
      console.log(val); // nothing prints, as the watcher does not run
      if (val.length > 1) {
        this.fighter_two.pop();
      }
    }
  },
  created() {
    axios
      .get("http://localhost:3000")
      .then(res => {
        this.rankings = res.data;
      })
      .catch(err => {
        console.log(err);
      });
  }
};
</script>

<style>
</style>

0 个答案:

没有答案