Drag拖动选择插件(原创)

所属分类:输入-拖和放,选择框

 20838  209  查看评论 (14)
分享到微信朋友圈
X
Drag拖动选择插件(原创) ie兼容10

更新时间:2019-11-23 00:24:04

更新说明:演示文档新增全选、全不选、反选按钮


更新时间:2019-11-21 00:16:46

DragSelect

简单的javascript拖动选择功能插件,类似 window 系统文件拖动选择效果,不依赖任何第三方项目

安装教程

1.CDN

<script src="https://thibaultjanbeyer.github.io/DragSelect/ds.min.js"></script>

2.npm

npm install --save dragselect

3.bower

bower install --save dragselect

4.将ds.min.js直接存放至你的网站空间

使用说明

1.一个最基础的实例,填写可被选中的元素

new DragSelect({
  selectables: document.getElementsByClassName('selectable-nodes')
});

2.在限定区域内生效,只能在选定的容器内部使用

new DragSelect({
  selectables: document.getElementsByClassName('selectable-nodes'),
  area: document.getElementById('area')
});

3.其他扩展,所有选项都是可选的,详情看参数和方法

var ds = new DragSelect({
  selectables: document.getElementsByClassName('selectable-nodes'), // 可被选中的元素节点
  selector: document.getElementById('rectangle'), // 可手动添加一个拖动选择框(译者:可用于修改拖动选择框的样式,需要手动添加 css 的 position:absolute 样式)
  area: document.getElementById('area'), // 拖动生效的区域,如果未提供,它将是整个网页文档
  customStyles: false,  // 如果设置为true,则默认情况下拖动选择框将不应用任何样式(绝对位置除外)
  multiSelectKeys: ['ctrlKey', 'shiftKey', 'metaKey'],  // 允许多选的特殊键,默认为 ctrl,shift,meta(Mac系统的专有键)
  multiSelectMode: false,  // 如果设置为true,则默认情况下将启用多选行为,而无需使用多选键,默认值:false
  autoScrollSpeed: 3,  // 选择时区域滚动的速度(如果有),单位是像素,设置为0以禁用自动滚动,默认值:1
  onDragStart: function(element) {}, // 用户点击该区域时触发此回调,在DragSelect函数代码运行之后执行,用于设置事件侦听器
  onDragMove: function(element) {}, // 用户拖动该区域时触发此回调,在DragSelect函数代码运行之后执行,用于设置事件侦听器   
  onElementSelect: function(element) {}, // 每次选择元素时触发的回调函数
  onElementUnselect: function(element) {}, // 每次取消选择元素时触发的回调函数
  callback: function(elements) {} // 用户释放鼠标后触发,返回所有被选定的元素节点
});
// 如果像我们一样将函数添加到变量中,则可以访问其所有函数
// 然后我们就可以先这样使用 start() 和 stop() 方法了
ds.getSelection();  // 返回所有被选定的元素节点
ds.addSelectables(document.getElementsByClassName('selectable-node'));  // 添加可以选择的元素,智能算法保证不会添加同个元素两次
ds.break();  // 在回调中使用以禁用即将执行的代码(译者:暂不知道有什么用)
ds.stop();  // 暂停功能
ds.start();  // 暂停后重启功能
// 还有更多内容,请参见文档中的“方法”部分

参数

所有选项都是可选的

参数类型用法
selectablesDOM elements (nodes)可被选中的元素节点
selectorsingle DOM element (node)可手动添加一个拖动选择框(译者:可用于修改拖动选择框的样式,需要手动添加 css 的 position:absolute 样式)
areasingle DOM element (node)拖动生效的区域,如果未提供,它将是整个网页文档
customStylesboolean如果设置为true,则默认情况下拖动选择框将不应用任何样式(绝对位置除外)
multiSelectKeysarray允许切换到多选模式的按键,可选的值有有:ctrlKey,shiftKey,metaKey(Mac系统的专有键)和altKey,默认=['ctrlKey', 'shiftKey', 'metaKey']。如果要关闭功能,请提供一个空数组[]
multiSelectModeboolean每次选中新元素时不清空旧的选中元素,默认='false'
autoScrollSpeedinteger选择时区域滚动的速度(如果有),单位是像素,设置为0以禁用自动滚动,默认值:1
selectedClassstring分配给选中项目的css类名称
hoverClassstring分配给鼠标悬停项目的css类名称(译者:并不是很理解这个的含义,估计用的不多)
selectorClassstring拖动选择框的css类名称
selectableClassstring给区域内所有可选元素添加的css类名称
onDragStartBeginfunction用户点击该区域时触发此回调,在DragSelect函数代码运行之前执行,用于设置事件侦听器
onDragStartfunction用户点击该区域时触发此回调,在DragSelect函数代码运行之后执行,用于设置事件侦听器
onDragMovefunction用户拖动该区域时触发此回调,在DragSelect函数代码运行之后执行,用于设置事件侦听器
onElementSelectfunction每次选择元素时触发的回调函数
onElementUnselectfunction每次取消选择元素时触发的回调函数
callbackfunction用户释放鼠标后触发,返回所有被选定的元素节点

方法

当函数保存到变量var foo = new DragSelect()中时,您可以访问其所有内部函数。

还有更多其他的方法,您可以在官方的文档中找到所有内容,这里只列举最常用的:

methodpropertiesusage
stop/暂停功能
start/暂停后重启功能
break/在回调中使用以禁用即将执行的代码(译者:暂不知道有什么用)
setSelectionDOM elements (nodes), Boolean (callback), Boolean (dontAddToSelectables)将选择内容设置为一个或多个元素。如果boolean设置为true:回调将在之后被调用。 默认情况下,它检查所有元素是否都在可选列表中,如果不存在则添加它们(可以通过将最后一个布尔值设置为true来关闭)
clearSelectionDOM elements (nodes), Boolean (callback)从选择中删除所有元素。如果boolean设置为true:回调将在之后被调用。
addSelectablesDOM elements (nodes), Boolean (addToSelection)添加可以选择的元素。智能的算法可确保节点永远不会被添加两次。如果boolean设置为true:元素也将添加到当前选择中。
removeSelectablesDOM elements (nodes), Boolean (removeFromSelection)删除可以选择的元素。如果boolean设置为true:元素也将从当前选择中删除。
getSelectables/返回所有选中元素节点数组。
setSelectablesDOM elements (nodes), Boolean (removeFromSelection), Boolean (addToSelection)设置所有可以选择的元素。删除所有当前的可选择项,添加新设置的选项到选项列表。如果应该从选择中删除旧元素,则第一个布尔值为true。如果要将新元素添加到选择中,第二个布尔值为true。


相关插件-拖和放,选择框

拖放交互的想法

在UI中拖放交互的一些想法,这个想法是显示一个可拖拽的区域,代表一个元素被拖拽后的某些动作。
  拖和放
 26563  345

jQuery移动端滑动标尺

移动端卡尺,滑动标尺,标不动
  拖和放
 25321  319

jQuery拖拽拉伸缩放插件l_zoom

简约版拖拽拉伸缩放原生jQuery插件 包含 自由缩放 和 等比例缩放 模式 经典还远网页文本框操作简单
  拖和放
 28910  328

JS表格列自由拖拽排序特效代码

该插件为纯js代码,实现表格列的自由拖拽,以及按列排序
  拖和放
 40495  405

讨论这个项目(14)回答他人问题或分享插件使用方法奖励jQ币 评论用户自律公约

    dlwlrma 0
    2022/11/29 9:19:39
    但是这有个问题:如果给固定高度的容器,里面元素很多,容器里面有滚动条,拖拽的时候滚动滚动条就选不中了 回复
    后来呢 0
    2022/1/6 16:46:59
    这个在vue里面怎么用啊大佬,急急急!!! 回复
    互联网+ 0
    2021/10/15 16:14:02
    你好!当要选择的对象过多时,框选会很卡顿,这个怎么解决呢?
        互联网+0
        2021/10/15 16:15:21
        比如我画了很多方格子,大概一页excel表格那么多,然后框选时就会很卡顿。
    回复
    0
    2020/8/11 11:15:50
    您看到了能不能加我一下Q,849372217这个问题有点让我上火,看到的话记得加我谢谢了! 回复
    0
    2020/8/10 18:19:43
    怎么引入angular呀,我引入进去以后不能new DragSelect({})
        0
        2020/8/11 11:16:52
        您看到消息加我一个Q(849372217),我这个有点点着急,谢谢啦
    回复
    随风过海 0
    2020/6/23 16:57:19
    插件反复实例化后 选择框的颜色变深了最后能变成深蓝色 回复
    随风过海 0
    2020/6/23 16:45:28
    插件反复实例化 后选择框 颜色变深了
        随风过海0
        2020/6/23 17:05:48
        _createSelector 是不是应该清一下然后再创建选择器?
        随风过海0
        2020/6/23 19:01:12
        我解决了 赞一个作者 这个插件还是很强的
        拾贝0
        2022/7/21 12:10:27
        怎么解决的啊,同样遇到这样的问题
    回复
    St.Bennie 0
    2019/11/27 15:40:22
    兄弟,这个插件,返回input 要怎么写?演示能加上id和值返回一下吗?
        ovsexia1
        2019/12/3 17:43:48

        演示的input标签改成这样

        <input type="checkbox" name="test[]" value="1" />

        script改成这样

        onElementSelect: function(element) {
            $(element).addClass('on').find('input[type="checkbox"]').prop('checked', true);
            input = $(element).find('input[name="test[]"]');
            console.log(input.val())
        },

        这个只是jq本身的语法,与插件无关

    回复
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
😃
  • 😀
  • 😉
  • 😥
  • 😵
  • 😫
  • 😘
  • 😡
  • 👍
  • 🌹
  • 👏
  • 🍺
  • 🍉
  • 🌙
  • 💖
  • 💔
取消回复