全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

JavaScript模拟文件拖选框样式v1.0的实例

文件拖选v1.0

图片不清楚时请右键点击"在新链接中打开图片"

实现效果

页面布局

实现思路

拖选框

css样式中设置拖选框样式,注意设置position: absolute;漂浮状态.

监听p#container的鼠标按下事件并获取起始坐标,鼠标按下时通过append()方法添加p#selectBox.

鼠标按下事件后鼠标移动事件,比较鼠标的当前位置event.pageX,event.pageY来为p#selectBox添加坐标top/left

和尺寸width/height.

鼠标离开p#container或鼠标松开事件后,remove()方法移除p#selectBox

单选

监听li点击事件;

通过li>子元素.lebal>子元素指向lebal使用toggleClass()方法修改背景样式(显示/取消勾选);

通过this指向li元素本身使用toggleClass()方法修改背景颜色;

复选

监听鼠标按下事件,按下时取消现有的leballi的勾选样式;

监听li,当鼠标移动到上面时,添加样式;

鼠标松开时移除mouseover事件,使它不会继续选中;

遗留问题

拖拽速度快时会有部分文件选不中,初步判断是代码执行效率低的问题

以某个文件为起点选择时,有时无法选中该文件

如果在该文件上短暂停留后可以选中,初步判断时代码执行效率低的问题

想要点击复选按钮时可以完成复选,但单选绑定的click事件与复选的mousedown事件冲突

点击复选按钮时会触发复选的mousedown,移除选择样式,代码逻辑问题

已解决 : 复选框的mousedown事件阻止冒泡 $(".lebal").bind('mousedown', function(event) {event.stopPropagation();})

360云盘复选框拖拽选中后再移开鼠标,则会取消判定该文件的选中,不清楚应该往哪里加逻辑

源代码

<<index.html>>

<!DOCTYPE html>
<html>

<head>
  <title></title>
  <script type="text/javascript" src="js/jquery-3.2.1.js"></script>
  <script type="text/javascript" src="js/script.js"></script>
  <link rel="stylesheet" type="text/css" href="css/style.css" rel="external nofollow" >
</head>

<body>
  <div id="container">
    <ul>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
      <li>
        <div class="lebal"><label></label></div>
        <div class="file_name"><p>文件列表</p></div>
      </li>
    </ul>
  </div>
</body>

</html>

<<style.css>>

* {margin: 0;padding: 0;}
body {height: 700px;border: 1px black solid;}
#selectBox {border: 1px solid #89d9ff;background-color: rgba(137, 217, 255, 0.5);position: absolute;display: block;}
#container {margin-top: 100px;margin-left: 200px;width: 1200px;height: 600px;border: 1px red solid;-webkit-user-select: none;-moz-user-select: none;-ms-user-select: none;user-select: none;}
ul {margin: 20px;}
li {width: 100%;height: 40px;border-top: 1px #ddd solid;list-style: none;}
label {background: url('../images/lebal.png')no-repeat;background-position: 0 0;width: 15px;height: 15px;margin: 12.5px auto;display: block;}
.toggleLebalClass {background-position: 0 -52px;}
.toggleLiClass {background: #eeefff;}
.lebal {width: 40px;height: 40px;float: left;}
.file_name {width: 80%;height: 40px;float: left;}
p {line-height: 40px;}

<<script.js>>

"use strict";
var x, y;
$(function() {
  // 点选
  $("li").bind('click', function(event) {
    $(this).children(".lebal").children().toggleClass("toggleLebalClass");
    $(this).toggleClass("toggleLiClass");
  });
  // 复选
  $(".lebal").bind('mousedown', function(event) {
    event.stopPropagation();
  })
  // 拖选
  $("#container").mousedown(function(event) {
    x = event.pageX;
    y = event.pageY;
    $("#container").append("<div id='selectBox'></div>");
    $("li").children(".lebal").children().removeClass("toggleLebalClass");
    $("li").removeClass("toggleLiClass");
    $("li").bind("mouseover", function() {
      $(this).children(".lebal").children().addClass("toggleLebalClass");
      $(this).addClass("toggleLiClass");
    });
  }).mousemove(function(event) {
    $("#selectBox").css({
      left: event.pageX > x ? x : event.pageX,
      top: event.pageY > y ? y : event.pageY,
      width: Math.abs(event.pageX - x),
      height: Math.abs(event.pageY - y)
    });
  }).mouseup(function(event) {
    $("#selectBox").remove();
    $("li").unbind("mouseover");
  })
  $("#container").mouseleave(function() {
    $("#selectBox").remove();
  })
});

以上这篇JavaScript模拟文件拖选框样式v1.0的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# js模拟文件拖选框样式  # 鼠标  # 文件列表  # 按下  # 复选  # 该文件  # 移除  # 不清楚  # 给大家  # 勾选  # 单选  # 复选框  # 拖拽  # 希望能  # 这篇  # 速度快  # 时请  # 则会  # 绑定  # 使它  # 小编 


相关文章: 无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  如何在局域网内绑定自建网站域名?  如何在万网开始建站?分步指南解析  如何选择PHP开源工具快速搭建网站?  C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)  建站之星各版本价格是多少?  c# 在高并发下使用反射发射(Reflection.Emit)的性能  如何快速搭建高效WAP手机网站吸引移动用户?  建站之星CMS建站配置指南:模板选择与SEO优化技巧  公司网站制作价格怎么算,公司办个官网需要多少钱?  专业网站制作服务公司,有哪些网站可以免费发布招聘信息?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  制作证书网站有哪些,全国城建培训中心证书查询官网?  如何在阿里云ECS服务器部署织梦CMS网站?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  企业微网站怎么做,公司网站和公众号有什么区别?  赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?  长沙做网站要多少钱,长沙国安网络怎么样?  如何选择建站程序?包含哪些必备功能与类型?  javascript基本数据类型及类型检测常用方法小结  建站之星展会模板:智能建站与自助搭建高效解决方案  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  建站之星2.7模板快速切换与批量管理功能操作指南  C++如何编写函数模板?(泛型编程入门)  如何用好域名打造高点击率的自主建站?  高防服务器租用如何选择配置与防御等级?  建站之星免费版是否永久可用?  如何获取免费开源的自助建站系统源码?  广州营销型建站服务商推荐:技术优势与SEO优化解析  网站制作的步骤包括,正确网址格式怎么写?  Android自定义listview布局实现上拉加载下拉刷新功能  如何快速搭建高效香港服务器网站?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  网站制作报价单模板图片,小松挖机官方网站报价?  油猴 教程,油猴搜脚本为什么会网页无法显示?  宿州网站制作公司兴策,安徽省低保查询网站?  宝塔建站后网页无法访问如何解决?  如何撰写建站申请书?关键要点有哪些?  太平洋网站制作公司,网络用语太平洋是什么意思?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  义乌企业网站制作公司,请问义乌比较好的批发小商品的网站是什么?  c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】  如何在建站主机中优化服务器配置?  建站之星Pro快速搭建教程:模板选择与功能配置指南  linux top下的 minerd 木马清除方法  长春网站建设制作公司,长春的网络公司怎么样主要是能做网站的?  制作网页的网站有哪些,电脑上怎么做网页?  昆明高端网站制作公司,昆明公租房申请网上登录入口?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。