JavaScript模拟文件拖选框样式v1.0的实例-创新互联
文件拖选v1.0
创新互联公司专注于企业营销型网站、网站重做改版、黑山网站定制设计、自适应品牌网站建设、H5响应式网站、购物商城网站建设、集团公司官网建设、外贸网站建设、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为黑山等各大城市提供网站开发制作服务。图片不清楚时请右键点击"在新链接中打开图片"
实现效果
页面布局
实现思路
拖选框
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()方法修改背景颜色;
复选
监听鼠标按下事件,按下时取消现有的lebal和li的勾选样式;
监听li,当鼠标移动到上面时,添加样式;
鼠标松开时移除mouseover事件,使它不会继续选中;
遗留问题
拖拽速度快时会有部分文件选不中,初步判断是代码执行效率低的问题
以某个文件为起点选择时,有时无法选中该文件
如果在该文件上短暂停留后可以选中,初步判断时代码执行效率低的问题
想要点击复选按钮时可以完成复选,但单选绑定的click事件与复选的mousedown事件冲突
点击复选按钮时会触发复选的mousedown,移除选择样式,代码逻辑问题
已解决 : 复选框的mousedown事件阻止冒泡 $(".lebal").bind('mousedown', function(event) {event.stopPropagation();})
360云盘复选框拖拽选中后再移开鼠标,则会取消判定该文件的选中,不清楚应该往哪里加逻辑
源代码
<
文件列表
文件列表
文件列表
文件列表
文件列表
文件列表
文件列表
文件列表
文件列表
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
标题名称:JavaScript模拟文件拖选框样式v1.0的实例-创新互联
网页地址:http://myzitong.com/article/dossch.html