欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用vuedraggable實(shí)現(xiàn)從左向右拖拽功能

 更新時(shí)間:2022年04月06日 10:29:14   作者:MasonYyp  
這篇文章主要為大家詳細(xì)介紹了使用vuedraggable實(shí)現(xiàn)從左向右拖拽功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了使用vuedraggable實(shí)現(xiàn)從左向右拖拽的具體代碼,供大家參考,具體內(nèi)容如下

1 功能描述

使用vuedraggable實(shí)現(xiàn)從左邊框中拖拽到右邊的框中,左邊的框不能隨意拖拽改變位置,不能向左邊框中拖拽組件。右邊框中的組件可以拖動(dòng)位置,但不能拖入到左邊框里。

注意事項(xiàng)如下:

(1)draggable的group中的name屬性必須一致;

(2)左邊框中的draggable必須含有以下屬性,group中的pull:'clone'屬性表示可以生成新的組件;group中的put:false屬性表示不能向里面拖拽組件;{sort: false}屬性表示不能更改組件的位置。

(3)左邊框中的draggable中的clone="cloneItem"表示組件被拖拽到右邊框中后,將生成的是新的組件,如果修改右邊組件的數(shù)據(jù)不會(huì)影響左邊組件的數(shù)據(jù)。cloneItem實(shí)現(xiàn)的是對(duì)每個(gè)組件的深復(fù)制。如果要實(shí)現(xiàn)修改兩邊框中的任何組件,兩邊組件都會(huì)同步變化,則需要?jiǎng)h除clone="cloneItem"屬性。

(4)右邊框中的draggable中的start屬性是監(jiān)聽開始拖動(dòng)組件,add是監(jiān)聽添加組件,可以根據(jù)情況調(diào)用其中的數(shù)據(jù)。

(5)從左邊框拖入右邊框中判斷單個(gè)數(shù)據(jù)是否合法,可以使用move屬性,如果,左側(cè)單個(gè)數(shù)據(jù)不合法返回false,則無法添加到右側(cè)框中。

2 截圖

3 源代碼

<template>
? <div class="my_draggle">
? ? <div class="md_title">使用vuedraggable實(shí)現(xiàn)從左到右拖拽</div>
? ??
? ? <div class="md_con">
? ? ? <draggable
? ? ? ? class="mdc_left"
? ? ? ? v-model="originDataArr"
? ? ? ? v-bind="{sort: false}"
? ? ? ? v-bind:group="{ name:'person', pull:'clone', put:false }"
? ? ? ? v-bind:clone="cloneItem">
?
? ? ? ? <div v-for="(item,index) in originDataArr" v-bind:key="index">
? ? ? ? ? <span>{{item.name}}</span>&nbsp;&nbsp;
? ? ? ? ? <span>{{item.sex}}</span>
? ? ? ? </div>
?
? ? ? </draggable>
?
? ? ? <draggable
? ? ? ? class="mdc_right"
? ? ? ? v-model="newDataArr"
? ? ? ? v-bind:group="{name:'person'}"
? ? ? ? v-on:start="dragItem"
? ? ? ? v-on:add="addItem">
? ? ? ? <div v-for="(item,index) in newDataArr" v-bind:key="index">
? ? ? ? ? <span><img v-bind:src="item.icon" /></span>&nbsp;&nbsp;
? ? ? ? ? <span>{{item.name}}</span>&nbsp;&nbsp;
? ? ? ? ? <span>{{item.sex}}</span>
? ? ? ? </div>
? ? ? </draggable>
? ? </div>
? </div>
</template>
?
<script>
?
import draggable from "vuedraggable"
?
export default {
? name: 'MyDraggle',
? components:{
? ? draggable
? },
? props: {
? ? msg: String
? },
? data: function(){
? ? return{
? ? ? originDataArr: new Array(),
? ? ? newDataArr: new Array()
? ? }
? },
?
? mounted: function(){
? ? this.initData();
? },
?
? methods: {
? ? initData: function(){
? ? ? this.originDataArr = [
? ? ? ? {name:"張三", age: 15, sex: "男", icon: require("@/assets/logo.png")},
? ? ? ? {name:"李四", age: 15, sex: "男", icon: require("@/assets/logo.png")},
? ? ? ? {name:"王五", age: 15, sex: "男", icon: require("@/assets/logo.png")},
? ? ? ? {name:"小花", age: 15, sex: "女", icon: require("@/assets/logo.png")}
? ? ? ]
? ? },
?
? ? cloneItem: function(val){
? ? ? // 深復(fù)制一個(gè)節(jié)點(diǎn)
? ? ? return JSON.parse(JSON.stringify(val))?
? ? },
?
? ? dragItem: function(widget){
? ? ? console.log(widget);
? ? },
?
? ? addItem: function(widget){
? ? ? console.log(widget);
? ? }
? }
}
</script>
?
<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
.my_draggle{
? position: relative;
}
?
.md_title{
? font-size: 24px;
? height: 60px;
}
?
.md_con>div{
? width: 600px;
? height: 600px;
? display: inline-block;
? border: 1px solid #CCCCCC;
? border-radius: 10px;
? vertical-align: top;
}
?
.mdc_left>div{
? height: 40px;
? line-height: 40px;
? margin-top: 6px;
? border: 1px solid #CCCCCC;
? cursor: move;
? margin: 10px 20px;
}
?
.mdc_left>div:hover{
? box-shadow: 1px 2px 4px #CCCCCC;
}
?
.mdc_right>div{
? height: 40px;
? line-height: 40px;
? margin-top: 6px;
? border: 1px solid #CCCCCC;
? cursor: move;
? margin: 10px 20px;
}
?
.mdc_right>div:hover{
? box-shadow: 1px 2px 4px #CCCCCC;
}
?
.mdc_right>div>span{
? display: inline-block;
? vertical-align: top;
}
?
.mdc_right>div>span>img{
? height: 30px;
}
?
</style>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue2中如何使用swiper@5.4.5

    vue2中如何使用swiper@5.4.5

    這篇文章主要介紹了vue2中如何使用swiper@5.4.5問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-12-12
  • vue + element-ui的分頁問題實(shí)現(xiàn)

    vue + element-ui的分頁問題實(shí)現(xiàn)

    這篇文章主要介紹了vue + element-ui的分頁問題實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue?input組件如何設(shè)置失焦與聚焦

    vue?input組件如何設(shè)置失焦與聚焦

    這篇文章主要介紹了vue?input組件如何設(shè)置失焦與聚焦,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 關(guān)于vue-color-顏色選擇器插件

    關(guān)于vue-color-顏色選擇器插件

    這篇文章主要介紹了關(guān)于vue-color-顏色選擇器插件,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • VUE子組件的watch不被觸發(fā)問題及解決

    VUE子組件的watch不被觸發(fā)問題及解決

    這篇文章主要介紹了VUE子組件的watch不被觸發(fā)問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 詳解打造 Vue.js 可復(fù)用組件

    詳解打造 Vue.js 可復(fù)用組件

    Vue.js 是一套構(gòu)建用戶界面的漸進(jìn)式框架。我們可以使用簡(jiǎn)單的 API 來實(shí)現(xiàn)響應(yīng)式的數(shù)據(jù)綁定和組合的視圖組件。
    2017-03-03
  • Vue proxyTable配置多個(gè)接口地址,解決跨域的問題

    Vue proxyTable配置多個(gè)接口地址,解決跨域的問題

    這篇文章主要介紹了Vue proxyTable配置多個(gè)接口地址,解決跨域的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • electron?dialog.showMessageBox的使用案例

    electron?dialog.showMessageBox的使用案例

    Electron?Dialog?模塊提供了api來展示原生的系統(tǒng)對(duì)話框,本文主要介紹了electron?dialog.showMessageBox的使用案例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-08-08
  • 解決vue cli使用typescript后打包巨慢的問題

    解決vue cli使用typescript后打包巨慢的問題

    這篇文章主要介紹了解決vue cli使用typescript后打包巨慢的問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • 詳解vue如何使用自定義指令

    詳解vue如何使用自定義指令

    在Vue的模板語法中,我們學(xué)了很多指令,當(dāng)然除了這些指令,Vue也允許我們自己定義自己的指令,所以本文就來和大家聊聊如何使用自定義指令吧
    2023-10-10

最新評(píng)論