欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript模擬文件拖選框樣式v1.0的實(shí)例

 更新時(shí)間:2017年08月04日 08:06:00   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇JavaScript模擬文件拖選框樣式v1.0的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

文件拖選v1.0

圖片不清楚時(shí)請(qǐng)右鍵點(diǎn)擊"在新鏈接中打開(kāi)圖片"

實(shí)現(xiàn)效果

頁(yè)面布局

實(shí)現(xiàn)思路

拖選框

css樣式中設(shè)置拖選框樣式,注意設(shè)置position: absolute;漂浮狀態(tài).

監(jiān)聽(tīng)p#container的鼠標(biāo)按下事件并獲取起始坐標(biāo),鼠標(biāo)按下時(shí)通過(guò)append()方法添加p#selectBox.

鼠標(biāo)按下事件后鼠標(biāo)移動(dòng)事件,比較鼠標(biāo)的當(dāng)前位置event.pageX,event.pageY來(lái)為p#selectBox添加坐標(biāo)top/left

和尺寸width/height.

鼠標(biāo)離開(kāi)p#container或鼠標(biāo)松開(kāi)事件后,remove()方法移除p#selectBox

單選

監(jiān)聽(tīng)li點(diǎn)擊事件;

通過(guò)li>子元素.lebal>子元素指向lebal使用toggleClass()方法修改背景樣式(顯示/取消勾選);

通過(guò)this指向li元素本身使用toggleClass()方法修改背景顏色;

復(fù)選

監(jiān)聽(tīng)鼠標(biāo)按下事件,按下時(shí)取消現(xiàn)有的leballi的勾選樣式;

監(jiān)聽(tīng)li,當(dāng)鼠標(biāo)移動(dòng)到上面時(shí),添加樣式;

鼠標(biāo)松開(kāi)時(shí)移除mouseover事件,使它不會(huì)繼續(xù)選中;

遺留問(wèn)題

拖拽速度快時(shí)會(huì)有部分文件選不中,初步判斷是代碼執(zhí)行效率低的問(wèn)題

以某個(gè)文件為起點(diǎn)選擇時(shí),有時(shí)無(wú)法選中該文件

如果在該文件上短暫停留后可以選中,初步判斷時(shí)代碼執(zhí)行效率低的問(wèn)題

想要點(diǎn)擊復(fù)選按鈕時(shí)可以完成復(fù)選,但單選綁定的click事件與復(fù)選的mousedown事件沖突

點(diǎn)擊復(fù)選按鈕時(shí)會(huì)觸發(fā)復(fù)選的mousedown,移除選擇樣式,代碼邏輯問(wèn)題

已解決 : 復(fù)選框的mousedown事件阻止冒泡 $(".lebal").bind('mousedown', function(event) {event.stopPropagation();})

360云盤(pán)復(fù)選框拖拽選中后再移開(kāi)鼠標(biāo),則會(huì)取消判定該文件的選中,不清楚應(yīng)該往哪里加邏輯

源代碼

<<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() {
  // 點(diǎn)選
  $("li").bind('click', function(event) {
    $(this).children(".lebal").children().toggleClass("toggleLebalClass");
    $(this).toggleClass("toggleLiClass");
  });
  // 復(fù)選
  $(".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的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 清除js緩存的多種方法總結(jié)

    清除js緩存的多種方法總結(jié)

    下面小編就為大家?guī)?lái)一篇清除js緩存的多種方法總結(jié)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-12-12
  • JavaScript localStorage使用教程詳解

    JavaScript localStorage使用教程詳解

    JavaScriptlocalStorage基本上是瀏覽器Window對(duì)象中的存儲(chǔ),您可以在中存儲(chǔ)任何內(nèi)容localStorage,localStorage及其相關(guān)的sessionStorage是 Web Storage API的一部分,我們將在本文詳細(xì)了解這些,需要的朋友可以參考下
    2023-06-06
  • 關(guān)于JavaScript中var聲明變量作用域的推斷

    關(guān)于JavaScript中var聲明變量作用域的推斷

    這個(gè)問(wèn)題其實(shí)之前困擾了我很久。如今終于想明白了,特來(lái)分享,如果有錯(cuò)誤的地方,請(qǐng)幫忙指正,我會(huì)隨時(shí)回來(lái)修正滴。
    2010-12-12
  • 原生JS實(shí)現(xiàn)呼吸輪播圖

    原生JS實(shí)現(xiàn)呼吸輪播圖

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)呼吸輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法

    關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法

    下面小編就為大家?guī)?lái)一篇關(guān)于RequireJS的簡(jiǎn)單介紹即使用方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • js控制頁(yè)面控件隱藏顯示的兩種方法介紹

    js控制頁(yè)面控件隱藏顯示的兩種方法介紹

    兩種方法的不同之處在于控件隱藏后是否還在頁(yè)面上占位,詳細(xì)的示例代碼如下,大家可以感受下
    2013-10-10
  • JavaScript實(shí)現(xiàn)向OL列表內(nèi)動(dòng)態(tài)添加LI元素的方法

    JavaScript實(shí)現(xiàn)向OL列表內(nèi)動(dòng)態(tài)添加LI元素的方法

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)向OL列表內(nèi)動(dòng)態(tài)添加LI元素的方法,實(shí)例分析了javascript操作html元素的技巧,需要的朋友可以參考下
    2015-03-03
  • Javascript 中介者模式實(shí)例

    Javascript 中介者模式實(shí)例

    在頁(yè)面上,用戶會(huì)有很多的操作 ,每進(jìn)行一次操作我們需要去展示操作的結(jié)果,在這里我們有了一個(gè)問(wèn)題,我們應(yīng)如何去展示不同的結(jié)果呢?
    2009-12-12
  • 利用Blob進(jìn)行文件上傳的完整步驟

    利用Blob進(jìn)行文件上傳的完整步驟

    BLOB (binary large object),二進(jìn)制大對(duì)象,是一個(gè)可以存儲(chǔ)二進(jìn)制文件的容器。下面這篇文章主要給大家介紹了關(guān)于利用Blob進(jìn)行文件上傳的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-08-08
  • js監(jiān)聽(tīng)鍵盤(pán)事件示例代碼

    js監(jiān)聽(tīng)鍵盤(pán)事件示例代碼

    本文為大家詳細(xì)介紹下使用js如何監(jiān)聽(tīng)鍵盤(pán)事件,具體實(shí)現(xiàn)代碼如下,感興趣的朋友可以參考下,希望對(duì)大家有所幫助
    2013-07-07

最新評(píng)論