日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

基于Fixed定位的框选功能

發(fā)布時間:2025/5/22 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 基于Fixed定位的框选功能 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

最近項目涉及到一個支持批量操作的小需求,交互上需要使用框選來觸發(fā)。在查閱了一些資料后發(fā)現(xiàn),網(wǎng)上的方案基本都是基于絕對定位布局的,此方案如果是針對全局(在body上)的框選,還是可用的。但是現(xiàn)實需求里幾乎都是針對某個區(qū)域的框選。如果用絕對定位實現(xiàn)就比較繁瑣了,需要調(diào)整定位原點。下面介紹一種基于Fixed定位的框選實現(xiàn)。

需求描述

  • 按住鼠標左鍵不放,移動鼠標出現(xiàn)選擇框
  • 在鼠標移動的過程中,在框選范圍內(nèi)的元素高亮
  • 松開鼠標左鍵,彈出編輯框,批量操作所有被框選的元素
  • 實現(xiàn)

    事件綁定

    首先梳理一下需要用到的事件。
    按住鼠標左鍵,因為并沒有原生的鼠標左鍵按下事件,所以使用mousedown事件配合setTimeout模擬實現(xiàn)。mousedown事件綁定在當前區(qū)域上。 使用一個標志變量mouseOn來代表是否開始繪制

    handleMouseDown(e) {// 判斷是否為鼠標左鍵被按下if (e.buttons !== 1 || e.which !== 1) return;this.settimeId = window.setTimeout(() => {this.mouseOn = true;// 設置選框的初始位置this.startX = e.clientX;this.startY = e.clientY;}, 300); }, handleMouseUp(e) {//在mouseup的時候清除計時器,如果按住的時間不足300毫秒//則mouseOn為falsethis.settimeId && window.clearTimeout(this.settimeId)if (!this.mouseOn) return; } 復制代碼

    鼠標移動,使用mousemove事件。 鼠標抬起,使用mouseup事件,注意抬起事件需要綁定在document上。因為用戶的框選操作不會局限在當前區(qū)域,在任意位置松開鼠標都應能夠結束框選的繪制。

    選框繪制

    在明確了事件之后,就只需要在幾個事件中填充具體的繪制和判斷邏輯了。先來看繪制的邏輯。在mousedown事件中,設置選框的初始位置,也就是鼠標按下的位置。這里我們提前寫好一個div,用來代表選框。

    <div class="promotion-range__select" ref="select"></div> .promotion-range__select {background: #598fe6;position: fixed;width: 0;height: 0;display: none;top: 0;left: 0;opacity:.6;pointer-events: none; } 復制代碼

    按下后顯示這個div并且設置初始定位即可

    this.$refs.select.style.cssText = `display:block;left:${this.startX}px;top:${this.startY}pxwidth:0;height:0;`; 復制代碼

    有了初始位置,在mousemove事件中,設置選框的寬高和定位。

    handleMouseMove(e) {if (!this.mouseOn) return;const $select = this.$refs.select;const _w = e.clientX - this.startX;const _h = e.clientY - this.startY;//框選有可能是往左框選,此時框選矩形的左上角就變成//鼠標移動的位置了,所以需要判斷。同理寬高要取絕對值this.top = _h > 0 ? this.startY : e.clientY;this.left = _w > 0 ? this.startX : e.clientX;this.width = Math.abs(_w);this.height = Math.abs(_h);$select.style.left = `${this.left}px`;$select.style.top = `${this.top}px`;$select.style.width = `${this.width}px`;$select.style.height = `${this.height}px`; }, 復制代碼

    如果使用絕對定位,就要去校準坐標原點了,在布局中嵌套多個relative定位容器的情況下,就非常繁瑣了。使用fixed定位就不需要考慮相對于哪個容器的問題了。

    判斷被框選的內(nèi)容

    //獲取目標元素 const selList = document.getElementsByClassName("promotion-range__item-inner" ); const { bottom, left, right, top } = $select.getBoundingClientRect(); for (let i = 0; i < selList.length; i++) {const rect = selList[i].getBoundingClientRect();const isIntersect = !(rect.top > bottom ||rect.bottom < top ||rect.right < left ||rect.left > right);selList[i].classList[isIntersect ? "add" : "remove"]("is-editing"); } 復制代碼

    判斷使用了getBoundingClientRect,定義引用自MDN

    返回值是一個 DOMRect 對象,這個對象是由該元素的 getClientRects() 方法返回的一組矩形的集合, 即:是與該元素相關的CSS 邊框集合 。

    DOMRect 對象包含了一組用于描述邊框的只讀屬性——left、top、right和bottom,單位為像素。除了 width 和 height 外的屬性都是相對于視口的左上角位置而言的。

    從定義中可以看到getBoundingClientRect中獲取的left、top、right和bottom是相對于視口左上角的,這和fixed定位的定義是一致的。因此,我們僅需要對比選框和被框選元素的四個定位值即可。

    rect.top > bottom 被框選元素位于選框上方

    rect.bottom < top 被框選元素位于選框下方

    rect.right < left 被框選元素位于選框左側

    rect.left > right 被框選元素位于選框右側

    排除這四種情況以外就是選框和被框選元素存在交集,給這些div加上class,因為移動過程中也需要讓用戶感知到被框選的元素,所以上述方法在mousemove中也要執(zhí)行。

    在mouseup中判斷被框選元素后,將選框置為display:none。

    功能demo地址

    github.com/juenanfeng/…

    參考鏈接

    www.jianshu.com/p/5052c6fd2…
    developer.mozilla.org/zh-CN/docs/…
    developer.mozilla.org/zh-CN/docs/…

    總結

    以上是生活随笔為你收集整理的基于Fixed定位的框选功能的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 天天干妹子 | 无码人妻黑人中文字幕 | 日韩中文字幕 | 成人av教育 | 国产日韩欧美日韩大片 | 国产99在线播放 | 成人免费黄色片 | 高清无打码 | 97超碰国产精品无码蜜芽 | 五月婷婷激情五月 | 在线观看中文字幕码 | 精品毛片| 三级av在线播放 | 手机av网 | www.成年人| 日本免费一区二区三区 | 五月婷婷丁香久久 | 最近中文字幕一区二区 | 久久国产亚洲 | 奶水喷溅 在线播放 | 日韩久久一区二区 | 伊人一二三| 久久深夜 | 亚洲av永久无码国产精品久久 | 在线观看免费黄网站 | 免费播放片大片 | 成人字幕 | 粉嫩精品久久99综合一区 | 美女网站在线看 | 欧美四级在线观看 | 在线www色| 亚洲激情欧美 | 国内自拍2020 | 中文字幕第一页在线视频 | 少妇粉嫩小泬喷水视频www | 中文字幕第4页 | 欧美一区二区三区久久妖精 | 色中文字幕在线观看 | 免费在线成人av | 一区二区在线精品 | 中文天堂网 | 日韩深夜视频 | 国产白丝喷水 | 3p视频在线| 国模私拍大尺度裸体av | 欧美丰满熟妇xxxx | 日本少妇一区二区三区 | 伊人情人综合网 | 青青草成人免费 | 国产99在线 | 亚洲 | 樱桃成人精品视频在线播放 | 男女激情啪啪 | 亚洲成人自拍网 | 97精品一区| 亚洲精品理论片 | 五月天婷婷导航 | 国产视频在线一区 | 91蝌蚪视频在线观看 | 欧美人禽杂交狂配 | 亚洲日本中文 | 天堂社区av | 成人77777 | 国产高清中文字幕 | av图片在线观看 | 中文字幕影片免费在线观看 | 九色自拍视频 | 国产一区二区播放 | av久久久久久 | 网站国产| 亚洲av无码片一区二区三区 | 欧美粗暴se喷水 | av在线手机版 | 中文字幕在线资源 | 成人精品视频99在线观看免费 | 河北彩花中文字幕 | 午夜精品久久久内射近拍高清 | 人人射影院 | 亚洲欧洲色 | 欧美三级少妇高潮 | 午夜偷拍福利视频 | 3344成人| 亚洲视频一区二区三区在线观看 | 国产香蕉av | 白嫩少妇激情无码 | 东京久久久 | 91国模少妇一区二区三区 | 婷婷九月 | 黄污视频在线播放 | 日韩在线视屏 | 老师用丝袜脚帮我脚交 | 五月天中文字幕 | 久久久久九九九九 | 亚洲精品一区二区二区 | 1024亚洲| 小sao货水好多真紧h无码视频 | 亚洲av电影一区二区 | 中文在线字幕免费观看电 | 色小说在线观看 | 日日狠狠久久 |