广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >使用纯JS实现checkbox的框选效果(鼠标拖拽多选)
  • 506
分享到

使用纯JS实现checkbox的框选效果(鼠标拖拽多选)

2024-04-02 19:04:59 506人浏览 八月长安
摘要

目录主要思路CSS 代码如下html结构如下js主要逻辑如下总结 主要思路 用一个盒子作为选区,通过定位让其固定在左上角,由于没有给定选区元素的宽高所以默认不显示,在 onmouse

主要思路

用一个盒子作为选区,通过定位让其固定在左上角,由于没有给定选区元素的宽高所以默认不显示,在 onmousemove 中动态获取选区定位的top left bottom right四个属性,同时将鼠标拖拽的距离作为选区的宽高,由于给选区元素的css设置了border就呈现出如图所示的框选效果。(注意:要想自己手动勾选复选框,要给选区元素的css设置pointer-events: none;否则点击复选框的事件会被选区遮挡)然后获取每个小复选框的位置和此时选区的位置进行比较来判断是否在选区内,如果满足条件就把复选框的checked属性设置为true。

css 代码如下

         * {
            user-select: none;
        }
        
        #ul {
            position: relative;
            width: 300px;
            height: auto;
            margin: 0 auto;
            padding: 100px;
        }
        
        li {
            display: inline-block;
            margin: 5px;
        }
        
        input {
            width: 30px;
            height: 30px;
        }
        
        #moveSelected {
            position: fixed;
            top: 0;
            left: 0;
            border: 1px dashed #2783F5;
            pointer-events: none;
        }

html结构如下

    <ul id="box">
        <li><input type="checkbox" id="check1"></li>
        <li><input type="checkbox" id="check2"></li>
        <li><input type="checkbox" id="check3"></li>
        <li><input type="checkbox" id="check4"></li>
        <li><input type="checkbox" id="check5"></li>
        <li><input type="checkbox" id="check6"></li>
        <li><input type="checkbox" id="check7"></li>
        <li><input type="checkbox" id="check8"></li>
        <li><input type="checkbox" id="check9"></li>
        <li><input type="checkbox" id="check10"></li>
        <li><input type="checkbox" id="check11"></li>
        <li><input type="checkbox" id="check12"></li>
        <li><input type="checkbox" id="check13"></li>
        <li><input type="checkbox" id="check14"></li>
        <li><input type="checkbox" id="check15"></li>
        <li><input type="checkbox" id="check16"></li>
        <li><input type="checkbox" id="check17"></li>
        <li><input type="checkbox" id="check18"></li>
        <li><input type="checkbox" id="check19"></li>
        <li><input type="checkbox" id="check20"></li>
        <!-- 选区 -->
        <li>
            <div id="moveSelected"></div>
        </li>
    </ul>

js主要逻辑如下

    window.onload = function() {
        let flag = false;//是否开启拖拽
        let oldLeft = 0; //鼠标按下时的位置
        let oldTop = 0;
        let box = document.getElementById('box') //操作区
        let moveSelected = document.getElementById("moveSelected");//选区
        let checkboxs = box.getElementsByTagName("input"); //复选框
        // 鼠标按下时开启拖拽,给选区设置定位
        box.onmousedown = function(e) {
                flag = true;
                moveSelected.style.top = e.pageY + 'px';
                moveSelected.style.left = e.pageX + 'px';
                oldLeft = e.pageX;
                oldTop = e.pageY;
            }
            // 鼠标移动时计算选区的位置和大小
        box.onmousemove = function(e) {
                if (!flag) return;
                if (e.pageX < oldLeft) { //表示左移
                    moveSelected.style.left = e.pageX + 'px';
                    moveSelected.style.width = (oldLeft - e.pageX) + 'px'; //向左移动的距离作为选区的宽
                } else {
                    moveSelected.style.width = (event.pageX - oldLeft) + 'px';
                }
                if (e.pageY < oldTop) { //向上移动
                    moveSelected.style.top = e.pageY + 'px';
                    moveSelected.style.height = (oldTop - e.pageY) + 'px';
                } else {
                    moveSelected.style.height = (e.pageY - oldTop) + 'px';
                }
                //通过得到的left和top加上元素自身的宽高来计算选区的right和bottom
                moveSelected.style.bottom = Number(moveSelected.style.top.split('px')[0]) + Number(moveSelected.style.height.split('px')[0]) + 'px';
                moveSelected.style.right = Number(moveSelected.style.left.split('px')[0]) + Number(moveSelected.style.width.split('px')[0]) + 'px';
                //找出选中的区域并激活
                for (let i = 0; i < checkboxs.length; i++) {
                    //计算每个checkbox的位置信息
                    let left = checkboxs[i].offsetLeft + box.offsetLeft;
                    let right = checkboxs[i].offsetWidth + left;
                    let top = checkboxs[i].offsetTop + box.offsetTop;
                    let bottom = checkboxs[i].offsetHeight + top;
                    //判断是否在选择区
                    let leftCover = moveSelected.style.left.split('px')[0] <= left && left <= moveSelected.style.right.split('px')[0];
                    let rightCover = moveSelected.style.left.split('px')[0] <= right && right <= moveSelected.style.right.split('px')[0];
                    let topCover = moveSelected.style.top.split('px')[0] <= top && top <= moveSelected.style.bottom.split('px')[0];
                    let bottomCover = moveSelected.style.top.split('px')[0] <= bottom && bottom <= moveSelected.style.bottom.split('px')[0];
                    if ((leftCover || rightCover) && (topCover || bottomCover)) {
                        checkboxs[i].checked = true;//激活复选框
                    }
                }
            }
            //鼠标抬起时清空选区数据
        box.onmouseup = function(e) {
                if (!flag) return;
                flag = false;
                moveSelected.style.width = 0;
                moveSelected.style.height = 0;
                moveSelected.style.top = 0;
                moveSelected.style.left = 0;
                moveSelected.style.bottom = 0;
                moveSelected.style.right = 0;
            }
            // 鼠标超出ul选区失效
        box.onmouseleave = function(e) {
            flag = false;
            moveSelected.style.width = 0;
            moveSelected.style.height = 0;
            moveSelected.style.top = 0;
            moveSelected.style.left = 0;
        }
    }

总结

到此这篇关于使用纯JS实现checkbox的框选效果的文章就介绍到这了,更多相关JS实现checkbox鼠标拖拽多选内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 使用纯JS实现checkbox的框选效果(鼠标拖拽多选)

本文链接: https://www.lsjlt.com/news/149149.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 使用纯JS实现checkbox的框选效果(鼠标拖拽多选)
    目录主要思路css 代码如下html结构如下js主要逻辑如下总结 主要思路 用一个盒子作为选区,通过定位让其固定在左上角,由于没有给定选区元素的宽高所以默认不显示,在 onmouse...
    99+
    2022-11-13
  • js如何实现登录框鼠标拖拽效果
    小编给大家分享一下js如何实现登录框鼠标拖拽效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!效果图:代码如下:<!DOC...
    99+
    2022-10-19
  • 如何使用纯CSS实现鼠标点击拖拽效果
    这篇文章主要介绍“如何使用纯CSS实现鼠标点击拖拽效果”,在日常操作中,相信很多人在如何使用纯CSS实现鼠标点击拖拽效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用纯CSS实现鼠标点击拖拽效果”的疑...
    99+
    2023-07-04
  • 怎样使用js实现百度登录框鼠标拖拽效果
    这篇文章主要介绍怎样使用js实现百度登录框鼠标拖拽效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!知识点:1.掌握对可拖拽对话框的实现原理2.了解元素如何触发脚本方法以及如何编写侦...
    99+
    2022-10-19
  • Vue利用draggable实现多选拖拽效果
    目录前言实现思路Demo全部代码Demo实现效果前言 最近产品提出一个排序需求,希望能进行拖拽排序,我一想,vue2插件这么多,sortable.js、draggable分分钟实现了...
    99+
    2022-11-13
  • 怎么用JavaScript实现div的鼠标拖拽效果
    这篇文章主要介绍“怎么用JavaScript实现div的鼠标拖拽效果”,在日常操作中,相信很多人在怎么用JavaScript实现div的鼠标拖拽效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Java...
    99+
    2023-06-25
  • 巧用纯CSS实现鼠标点击拖拽效果,让交互更加生动!
    实际应用OK,用了比较大篇幅对原理进行了描述。下面我们举一个实际的应用场景。使用上述技巧制作的可拖动便签贴。灵感来自 -- scottkellum。代码也不多,如果你了解了上面的内容,下面的代码将非常好理解:<div class=&q...
    99+
    2022-11-22
    css
  • 如何使用Vue实现一个简单的鼠标拖拽滚动效果插件
    这篇文章主要介绍了如何使用Vue实现一个简单的鼠标拖拽滚动效果插件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。 演示事例最近在做...
    99+
    2022-10-19
  • 如何使用javascript实现鼠标框的效果
    鼠标框是一种常见的交互效果,在网页设计和开发中得到广泛应用。使用 javascript 实现鼠标框不仅可以增强用户体验,还可以为网页添加更多的交互效果。在本文中,我们将介绍如何使用 javascript 实现鼠标框的效果,向大家详细地介绍实...
    99+
    2023-05-14
  • 使用:active伪类选择器实现鼠标点击效果的CSS样式
    使用:active伪类选择器实现鼠标点击效果的CSS样式CSS是一种层叠样式表语言,用于描述网页的表现和样式。:active是CSS中的一个伪类选择器,用于选择元素在鼠标点击时的状态。通过使用:active伪类选择器,我们可以为被点击的元素...
    99+
    2023-11-20
    伪类 :active 鼠标点击效果
  • 使用:hover伪类选择器实现鼠标悬停效果的CSS样式
    使用:hover伪类选择器实现鼠标悬停效果的CSS样式在网页设计中,鼠标悬停效果是提升用户体验和界面交互性的重要一环。通过CSS的:hover伪类选择器,我们可以轻松实现鼠标悬停时元素的样式变化。本文将给出具体的代码示例,帮助你快速上手使用...
    99+
    2023-11-20
    :hover 伪类选择器 鼠标悬停效果
  • 使用python tkinter实现各种个样的撩妹鼠标拖尾效果
    目录一、系统拖尾二、文艺型拖尾三、实用型拖尾四、爱心拖尾五、奔跑的火柴人型拖尾六、胡桃摇钱拖尾七、女朋友或者老婆拖尾python-tkinter 实现各种个样的撩妹鼠标拖尾,效果图展...
    99+
    2022-11-12
  • 怎么使用纯CSS实现蝴蝶标本的展示框效果
    这篇文章主要为大家展示了“怎么使用纯CSS实现蝴蝶标本的展示框效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么使用纯CSS实现蝴蝶标本的展示框效果”这篇文...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作