利用Javascript獲取選擇文本所在的句子詳解-創(chuàng)新互聯(lián)

前言

創(chuàng)新互聯(lián)公司2013年成立,先為策勒等服務(wù)建站,策勒等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為策勒企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

最近收到一個 issue 期望能在劃詞的時候同時保存單詞的上下文和來源網(wǎng)址。這個功能其實很久之前就想過,但感覺不好實現(xiàn)一直拖延沒做。真做完發(fā)現(xiàn)其實并不復(fù)雜,完整代碼在這里,或者繼續(xù)往下閱讀分析。話不多說了,來一起看看詳細的介紹吧。

原理分析

獲取選擇文本

通過 window.getSelection() 即可獲得一個 Selection 對象,再利用 .toString() 即可獲得選擇的文本。

錨節(jié)點與焦節(jié)點

在 Selection 對象中還保存了兩個重要信息,anchorNode 和 focusNode,分別代表選擇產(chǎn)生那一刻的節(jié)點和選擇結(jié)束時的節(jié)點,而 anchorOffset 和 focusOffset 則保存了選擇在這兩個節(jié)點里的偏移值。

這時你可能馬上就想到第一個方案:這不就好辦了么,有了首尾節(jié)點和偏移,就可以獲取句子的頭部和尾部,再把選擇文本作為中間,整個句子不就出來了么。

當(dāng)然不會這么簡單哈stuck_out_tongue。

強調(diào)一下

一般情況下,anchorNode 和 focusNode 都是 Text 節(jié)點(而且因為這里處理的是文本,所以其它情況也會直接忽略),可以考慮這種情況:

<strong>Saladict</strong> is awesome!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

網(wǎng)頁名稱:利用Javascript獲取選擇文本所在的句子詳解-創(chuàng)新互聯(lián)
文章來源:http://muchs.cn/article22/hehjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、營銷型網(wǎng)站建設(shè)面包屑導(dǎo)航、標(biāo)簽優(yōu)化搜索引擎優(yōu)化、品牌網(wǎng)站建設(shè)

廣告

聲明:本網(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è)