欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

用js的selectionrange操作選擇區(qū)域內(nèi)容和圖片

先放上最后的效果,這是點擊圖片以前:

我們提供的服務(wù)有:成都網(wǎng)站設(shè)計、成都網(wǎng)站制作、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、路橋ssl等。為近千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務(wù),是有科學(xué)管理、有技術(shù)的路橋網(wǎng)站制作公司

用 js 的 selection range 操作選擇區(qū)域內(nèi)容和圖片

這是點擊圖片以后:

用 js 的 selection range 操作選擇區(qū)域內(nèi)容和圖片

非常清晰,一目了然,就算是小白用戶也明白發(fā)生了什么。挺好的。

最近在做編輯器相關(guān)的東西,遇到一個需求,用戶在編輯器中插入或者粘貼的圖片要支持點擊以后,可以按 Backspace 鍵或者 Delete 鍵刪除掉。

剛開始拿到這個需求的想法是調(diào)用編輯器自帶的刪除圖片方法刪掉圖片,但后來查看源碼發(fā)現(xiàn)這個方法是編輯器內(nèi)部方法,并沒有暴露出來,于是第一個思路走不通了。

第二個思路是在編輯器的頂層容器里監(jiān)聽 keyup 事件,然后判斷是否是兩個刪除鍵,如果是就攔截,然后找到當前點擊的圖片,手動刪掉。

實際上這也是行不通的,原因有二。首先,這個刪除是沒法阻止的,因為事件的監(jiān)聽是在頂層父元素里,這時候阻止其實是阻止掉事件在頂層容器上的效果,而不是在發(fā)生元素上的效果。所有涉及到事件冒泡的地方,在父容器上阻止效果都是不能達到目的的,只能在事件最開始發(fā)生的元素上阻止。 

然后,當按下刪除鍵的時候,之前點擊的圖片已經(jīng)不是點擊狀態(tài)了,已經(jīng)拿不到了。因為取消選擇在前,刪除在后。

后來忽然意識到,想要的效果其實就是點擊圖片的時候選中圖片,就像用戶自己選中網(wǎng)頁中一段內(nèi)容那樣選中那張圖片就好了。頁面上點擊一個圖片默認是沒有效果的,我要做的僅僅是點擊時候選中這個圖片就可以了。這樣做的好處是,當用戶點擊圖片選中以后,如果點刪除鍵,無論是 Backspace 還是 Delete 鍵都可以刪除;而且如果用戶不像刪除,直接點擊別的地方,或者按下上下左右箭頭就可以取消選擇,這和用戶平時的操作體驗是一樣的,根本沒有什么副作用。

selection 是 HTML5 的新接口,是 window 的一個方法,用法是 window.getSelection().

取得 selection 以后,要把當前圖片加入到選取中,selection 有一個 Selection.selectAllChildren() 方法,但這個方法只能選中元素的全部子元素,而我們要選中的是 img 元素自身,img 元素也沒有子元素。于是繼續(xù)在 selection 的方法中看看有沒有別的長的像的方法,果然,找到了 Selection.addRange() 看這長相一看就很像我們要找的人。addRange 方法需要傳入一個 range 對象,range是啥呢?

平時在頁面上選擇東西都是鼠標咔一下框一大片,但如果在編輯器里,其實是可以選擇好幾個片段的,一般按住 Ctrl / Control 鍵就可以多處選擇。我猜這個 selection 就類似于選中的所有區(qū)域,range 就類似于每一個單獨的選中的片段,先這么理解。

繼續(xù)往下看,發(fā)現(xiàn) range 有一個 Range.selectNode() 方法,這不正是我要找的人嗎?先創(chuàng)建一個 range 對象,let range = document.createRange()  createRange 是 document 的方法,然后講當前圖片插入 range,再把 range 插入 selection 中即可。代碼如下:

let checkClickImg = function(e) {
 let target = e.target;
 if (target.nodeName.toLowerCase() === 'img') {
  // 刪除之前所有的選區(qū)
  window.getSelection().removeAllRanges();
  let selection = window.getSelection();
  let range = document.createRange();
  range.selectNode(target);
  selection.addRange(range);
 }
}

這個實現(xiàn)方法的最大優(yōu)點在于利用瀏覽器原生自帶的功能,這樣就和用戶的操作習(xí)慣保持一致,不會有任何的突兀。選中的效果很明顯,而且選中以后無論是刪除,還是取消,都跟之前習(xí)慣一致,都很容易,更要的是這些操作不用再寫代碼了啊,因為是瀏覽器原生自帶的功能。

嗯,算是比較完美了。

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持創(chuàng)新互聯(lián)!

新聞標題:用js的selectionrange操作選擇區(qū)域內(nèi)容和圖片
網(wǎng)站鏈接:http://aaarwkj.com/article0/jeijoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT微信小程序、網(wǎng)站改版、靜態(tài)網(wǎng)站、品牌網(wǎng)站制作、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)
日本一区二区三区高清不卡| 日本日韩一区二区国产| 色呦呦视频在线免费看| 亚洲精品中文一区二区三区| 成人高清乱码一区二区三区| 国产精品美女露脸av毛片| 日本免费一区二区在线视频| 日韩精品女性三级视频| 国产成人综合欧美日韩另类| 婷婷国产综合一区二区三区| 久久女婷五月综合色啪色老板| 亚洲黄色片大奶子水多| 亚洲精品乱码精品乱码不卡| 亚洲一区二区三区熟女av| 在线激情av中文字幕| 人人妻人人澡人人揉| 粉嫩美女精品一区二区| 欧美另类亚洲综合久青草 | 日本高清久久一区二区三区| 天堂在线手机av观看| 小黄片视频免费在线播放| 国产三级精品久久三级国专区| 大陆av剧情网站在线观看| 中国吞精囗交免费视频| jk黑丝白丝国产精品| 中文字幕女同系列av厨房| 欧美性大片免费在线观看| 香蕉夜夜草草久久亚洲香蕉| 内射极品美女在线观看| 国产精品一区二区啪啪| 中文字幕有码av海量| 亚洲av综合日韩精品久久| 日本日本熟妇在线视频| 日本一区二区精美视频| 亚洲成av人的天堂在线观看女人| 日韩欧美亚洲一区二区三区| 国产黄色一区二区三区,| sedoge在线播放免费有码| 国产精品九九久久精品三级| 亚洲性图中文字幕在线| 成年人免费国产视频网站|