我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Vue拖拽排序组件Vue-Slicksort怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Vue拖拽排序组件Vue-Slicksort怎么使用

这篇“Vue拖拽排序组件Vue-Slicksort怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue拖拽排序组件Vue-Slicksort怎么使用”文章吧。

    一、效果图

    Vue拖拽排序组件Vue-Slicksort怎么使用

    二、安装组件

    npm i vue-slicksort -S

    三、使用组件

    <div class="maintenance_img mt50 mb50 pl20 pr20" >    <!-- 拖拽 -->    <SlickList        :lockToContainerEdges="true"        lockAxis="x"        axis="x"        v-model="maintenanceData.img_list"        @input="getChangeLists"                >        <SlickItem  v-for="(item, index) in maintenanceData.img_list" :index="index" :key="index">            <div class="maintenance_top">                <img :class="lazy" data-src="item" @mouseover="changeMask(index)" @mouseout="changeMask(index)" alt="">            </div>        </SlickItem>    </SlickList>    <div >        <div class="maintenance_icon" v-for="(item, index) in maintenanceData.img_list" :key="index">            <div class="img_bg" :ref="'mask' + index" @mouseover="changeMask(index)" @mouseout="changeMask(index)">                <Icon @click.stop="isImgShow = true;bigImg = item" class="pointer" size="20" color="#000000" type="md-search" />                <Icon @click.stop="downloadImg(item)" class="pointer" size="20" color="#000000" type="md-download" />                <Icon @click.stop="movingItems(4, index)" class="pointer" size="20" color="#000000" type="md-trash" />            </div>        </div>    </div>    <!-- 600*330 -->    <div class="add-img" v-if="maintenanceData.img_list.length<5">        <span>            <Icon type="md-add" size="30"></Icon>        </span>        <p>添加图片</p>        <input @change="uploadImegs($event, 1)" type="file" accept="image/*" />    </div></div>
        import { SlickList, SlickItem } from "vue-slicksort";    export default {        components:{            SlickItem,            SlickList        },        data() {            return {                maintenanceData: {                    img_list: [], //图片                },            }        },        created() {                    },        methods: {            getChangeLists(vals) {                // 拖拽完成后返回新的排序数组                console.log(vals);            },        },    }
    .maintenance_top {    display: flex;    z-index: 10000;}.maintenance_top {    width: 140px;    height: 78px;    border: 1px dashed #ccc;    border-radius: 6px;    display: flex;    align-items: center;    position: relative;    margin-right: 15px;}.maintenance_top > img{    max-width: 138px;    max-height: 138px;    border-radius: 6px;}.maintenance_icon{    width: 140px;    display: flex;    align-items: center;    position: relative;    margin-right: 15px;}.maintenance_img{    display: flex;}.maintenance_img>div>div{    z-index: 10000;}.maintenance_img > .add-img{    display: block;    width: 140px;    height: 78px;    border-radius: 6px;} .img_bg{    width: 100%;    height: 40px;    position: absolute;    bottom: -20px;    left: 0;    border-radius: 6px;    display: none;    align-items: center;    justify-content: space-evenly;}

    四、组件参数

    名称类型默认值说明
    valueArray-列表的内容
    axisStringy列表元素可以被横向拖拽,纵向拖拽还是网格拖拽。用x,y,xy来表示
    lockAxisArray-用于排序时在坐标系中锁定元素的移动
    helperClassString-helper的自定义样式类
    transitionDurationNumber300元素移动动画的持续时间
    pressDelayNumber0如果需要当元素被按下一段时间再允许拖拽,可以设置这个属性
    pressThresholdNumber5移动允许被忽略的阈值,单位是像素
    distanceNumber0如果需要在拖拽出一定距离之后才被识别为正在拖拽的元素,可以设置这个属性
    useDragHandleBooleanfalse如果使用HandleDirective,设置为true
    useWindowAsScrollContainerBooleanfalse是否设置window为可滚动的容器
    hideSortableGhostBooleantrue是否自动隐藏ghost元素
    lockToContainerEdgesBooleanfalse是否对正在拖拽的元素锁定容器边缘
    lockOffsetString50%对正在拖拽的元素锁定容器边缘的偏移量
    shouldCancelStartFunction-在拖拽开始前这个方法将被调用
    getHelperDimensionsFunction-可选方法({node, index, collection}),用于返回SortableHelper的计算尺寸

    五、组件方法

    名称参数说明
    sortStartevent, node, index, collection当拖拽开始时触发
    sortMoveevent当拖拽时鼠标移动时触发
    sortEndevent, newIndex, oldIndex, collection当拖拽结束时触发
    inputnewList当拖拽结束后产生新的列表时触发

    HandleDirective

    v-handle 指令在可拖动元素内部使用。(即用了这个指令,可以让拖动只在元素的某个位置生效)

    Container 必须由 :useDragHandle 属性,且设置为 true 时才能正常工作。

    这里有关于此的一个简单元素的例子:

    <template><li class="list-item">    <!-- 拖动只在 span 元素上生效 -->    <span v-handle class="handle"></span>    {{item.value}}</li></template><script>    import { ElementMixin, HandleDirective } from 'vue-slicksort';    export default {        mixins: [ElementMixin],        directives: { handle: HandleDirective },    };</script>

    以上就是关于“Vue拖拽排序组件Vue-Slicksort怎么使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    Vue拖拽排序组件Vue-Slicksort怎么使用

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    Vue拖拽排序组件Vue-Slicksort怎么使用

    这篇“Vue拖拽排序组件Vue-Slicksort怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue拖拽排序组件V
    2023-07-05

    Vue拖拽排序组件Vue-Slicksort解读

    这篇文章主要介绍了Vue拖拽排序组件Vue-Slicksort,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-10

    VUE怎么使用draggable实现组件拖拽

    这篇文章主要讲解了“VUE怎么使用draggable实现组件拖拽”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VUE怎么使用draggable实现组件拖拽”吧!实现步骤1、导入draggab
    2023-06-29

    Vue可拖拽组件Vue Smooth DnD的使用方法

    本篇内容主要讲解“Vue可拖拽组件Vue Smooth DnD的使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue可拖拽组件Vue Smooth DnD的使用方法”吧!目录简介和 De
    2023-06-20

    vue怎么实现列表拖拽排序效果

    这篇文章主要介绍“vue怎么实现列表拖拽排序效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么实现列表拖拽排序效果”文章能帮助大家解决问题。效果如下: