精品专区-精品自拍9-精品自拍三级乱伦-精品自拍视频-精品自拍视频曝光-精品自拍小视频

網(wǎng)站建設(shè)資訊

NEWS

網(wǎng)站建設(shè)資訊

利用Fixed定位怎么實現(xiàn)框選功能-創(chuàng)新互聯(lián)

利用Fixed定位怎么實現(xiàn)框選功能?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

創(chuàng)新互聯(lián)長期為上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為五常企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站建設(shè),五常網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

實現(xiàn)

事件綁定

首先梳理一下需要用到的事件。

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

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

這里有一個小的注意點,就是clearTimeout一定要寫成 window.clearTimeout ,否則在vue里會報錯timeout.close is not a function,具體的原因尚未找到,有大佬了解望告知。

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

選框繪制

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

.promotion-range__select {  background: #598fe6;  position: fixed;  width: 0;  height: 0;  display: none;  top: 0;  left: 0;  opacity:.6;  pointer-events: none; }

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

this.$refs.select.style.cssText = `display:block;
                  left:${this.startX}px;
                  top:${this.startY}px
                  width:0;
                  height:0;`;

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

handleMouseMove(e) {
 if (!this.mouseOn) return;
 const $select = this.$refs.select;
 const _w = e.clientX - this.startX;
 const _h = e.clientY - this.startY;
 //框選有可能是往左框選,此時框選矩形的左上角就變成
 //鼠標(biāo)移動的位置了,所以需要判斷。同理寬高要取絕對值
 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`;
},

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

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

//獲取目標(biāo)元素
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() 方法返回的一組矩形的集合, 即:是與該元素相關(guān)的CSS 邊框集合 。

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

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

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

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

rect.right < left 被框選元素位于選框左側(cè)

rect.left > right 被框選元素位于選框右側(cè)

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

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

看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。


標(biāo)題名稱:利用Fixed定位怎么實現(xiàn)框選功能-創(chuàng)新互聯(lián)
文章出自:http://m.jcarcd.cn/article/cedhpi.html

其他資訊

主站蜘蛛池模板: 欧美亚洲日韩国产网 | 国产精品第18页 | 欧美做人爱a毛 | 成人拍拍拍在线观看 | 国产精品精品精品 | 日本高清一 | 人人澡人 | 成人三级网站在 | 91中文字| 女同欧洲 | 国产大片亚州一 | 青青国产在线观看 | 日韩精品在线视频 | 精品日产乱 | 日韩精品动漫一区 | 99r精品在线观看 | 国产区在线视频 | 国产网站91 | 成人午夜婬片A | 国产二区自拍 | 午夜福利在线导航 | 国产黄在 | 日本免费国产 | 青青操视频免费观看 | 精品免费 | 国产综合在线播放 | 毛色免费美女视频 | 中文字幕第二页 | 国产福利影院 | 福利一区在线观看 | 91性爱网| 九九在线精品视频 | 国产精品露脸国语 | 欧美在线区 | 国产精品色女人 | 国内91精 | 九九热在线视频观看 | 日韩电影在线电影 | 91啦视频在线观看 | 成人高清网站 | 午夜成人|