中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

javascript的range使用方法有哪些

這篇“javascript的range使用方法有哪些”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“javascript的range使用方法有哪些”文章吧。

成都創(chuàng)新互聯(lián)主要從事成都做網(wǎng)站、網(wǎng)站制作、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)云龍,10多年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):13518219792

javascript的range對(duì)象是指html文檔中的區(qū)域,其使用方法如“var elem=range.commonAncestorContainer;if(elem.nodeType != 1){...}”。

javascript的range使用方法有哪些

本文操作環(huán)境:Windows7系統(tǒng)、javascript1.8.5版、Dell G3電腦。

javascript的range用法是什么?

JS Range 對(duì)象的使用

一:什么是Range對(duì)象

Range是指html文檔中的區(qū)域,如用戶用鼠標(biāo)拖動(dòng)選中的區(qū)域,如下圖:

javascript的range使用方法有哪些

通過Range對(duì)象,可以獲取用戶選中的區(qū)域,或者指定選中區(qū)域,得到Range的起點(diǎn)和終點(diǎn)、修改或者復(fù)制里邊的文本,甚至是html。在富文本編輯器開發(fā)中,經(jīng)常會(huì)使用到這些功能。

二:獲取當(dāng)前的選區(qū)

由于兼容性的問題,需要區(qū)分ie瀏覽器,

var selection, range;
if (window.getSelection) { 
    //現(xiàn)代瀏覽器
    selection = window.getSelection();
} else if (document.selection) { 
    //IE
    selection = document.selection.createRange();
}

//Range對(duì)象
range = selection.getRangeAt(0);

三:range屬性

> collapsed     如果范圍的開始點(diǎn)和結(jié)束點(diǎn)在文檔的同一位置,則為 true,即范圍是空的,或折疊的。
> commonAncestorContainer     范圍的開始點(diǎn)和結(jié)束點(diǎn)的(即它們的祖先節(jié)點(diǎn))、嵌套最深的 Document 節(jié)點(diǎn)。
> endContainer         包含范圍的結(jié)束點(diǎn)的 Document 節(jié)點(diǎn)。 
> endOffset     endContainer 中的結(jié)束點(diǎn)位置。
> startContainer     包含范圍的開始點(diǎn)的 Document 節(jié)點(diǎn)。
> startOffset    startContainer中的開始點(diǎn)位置。

四:range操作

//選中區(qū)域的文字
var text = range.toString();

//選中區(qū)域的Element元素
var elem = range.commonAncestorContainer;
if(elem.nodeType != 1){
     elem = elem.parentNode;
}

//選中區(qū)域的html
var span = document.createElement('SPAN');
span.appendChild(range.cloneContents());

//選區(qū)是否為空
var isSelectionEmpty = false;
if (range.startContainer === range.endContainer) {
   if (range.startOffset === range.endOffset) {
       isSelectionEmpty = true;
   }
}

以上就是關(guān)于“javascript的range使用方法有哪些”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享標(biāo)題:javascript的range使用方法有哪些
URL標(biāo)題:http://www.rwnh.cn/article20/igjgco.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)建站公司、動(dòng)態(tài)網(wǎng)站、網(wǎng)站設(shè)計(jì)、軟件開發(fā)品牌網(wǎng)站建設(shè)

廣告

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

微信小程序開發(fā)
芜湖市| 任丘市| 津市市| 遂平县| 琼结县| 藁城市| 南漳县| 长治市| 淮滨县| 永昌县| 堆龙德庆县| 青田县| 丰镇市| 吉林省| 鹿邑县| 磐安县| 抚州市| 上林县| 八宿县| 临泽县| 孝义市| 行唐县| 广河县| 元朗区| 若羌县| 福海县| 十堰市| 樟树市| 南皮县| 开平市| 乐平市| 安岳县| 元阳县| 隆化县| 嵩明县| 淮安市| 大丰市| 星子县| 肥乡县| 肥城市| 年辖:市辖区|