在 HTML5 中,一个 Range 对象代表页面上的一段连续区域。通过 Range 对象,可以获取或修改页面上的任何区域。包含获取,修改,删除和替换等操作。

一:获取range对象的值

Range对象提供鼠标选取功能,通过Range对象可以获得选取的内容,以及选取的内容的个数。

var s  = document.getSelection();//此方法获得选中内容,获取range对象

s.rangeCount;//获得选中个数

 function rangeText(){
var e_showrange=document.getElementById('showRanage');
var selection=document.getSelection();
alert(selection.rangeCount);
if(selection.rangeCount){
var html="";
for (var i=0;i<selection.rangeCount;i++) {
html+="第"+(i+1)+"个内容为"+selection.getRangeAt(i);
};
e_showrange.innerHTML=html;
}
}

s.getRangeAt(index);// The Range object that will be returned.

var ranges = [];

sel = window.getSelection();

for(var i = 0; i < sel.rangeCount; i++) {
ranges[i] = sel.getRangeAt(i);
}
/* Each item in the ranges array is now
* a range object representing one of the
* ranges in the current selection */

s.getRangeAt的浏览器的支持比较:

二: 删除range对象的值

var rangeObj = document.createRange();//创建range对象

var node = $("#node");

rangeObj .selectNode(node);//选择节点

rangeObj .selectNodeContents(node);//选择节点中的内容

rangeObj .deleteContents();//从页面上删除节点或者节点中的内容,选择的是节点删除节点,选择的是节点中的内容删除内容

<div id="deL_node">要删除的节点的内容</div>
<div id="del_node2">要删除的节点2</div>
<button onclick="removeRangeContents()">删除内容</button>
<button onclick="removeRangeNode()">删除元素节点</button> function removeRangeNode(){
var delNode2=document.getElementById('del_node2');
var rangeObj=document.createRange();
rangeObj.selectNode(delNode2);
rangeObj.deleteContents();
}
function removeRangeContents(){
var delNode=document.getElementById('deL_node');
var rangeObj=document.createRange();
rangeObj.selectNode(delNode);
rangeObj.selectNodeContents(delNode); //会覆盖上面的节点的选中
rangeObj.deleteContents(); //结果为删除内容
}

设置Range的起始和结束:

1.先获得需要删除内容的节点

2.获得内容

3.设置起始和结束

4.删除

假设一个div中是内容

var div = $("node");

var text = div.firstChild;//获得内容不是子节点

rangeObj .setStart(text,1);//设置第一个文字或字符为开始

rangeObj .setEnd(text,8);//设置第8个字符或文字为结束

rangeObj .deleteContents();//删除

可通过r.setStartBefore(node)和r.setEndAfter(node);方法设置Range的起始和结束,设置在一个节点开始之前与一个节点结束之后。

对应还有setStartAfter(node);和setEndBefore(node)节点开始后和节点结束前。

<div id="del_node3">要删除的节点</div>
<button onclick="removeSelctContents()">删除内容</button> function removeSelctContents(){
var delNode3=document.getElementById('del_node3');
var rangeObj=document.createRange();
var text = delNode3.firstChild;
console.log(text);
console.log(typeof(text));
rangeObj.setStart(text,0);
rangeObj.setEnd(text,3);
rangeObj.deleteContents();
} //输出结果
将删除 “要删除” 三个字

三、克隆

rangeObj.cloneContents()   //克隆内容

<div id="clone_3">
我吃饭了
<button onclick="range_clone2()">点击复制</button>
</div>
function range_clone2(){
var dom3=document.getElementById('clone_3');
var rangeObj=document.createRange(); //创建一个range对象
rangeObj.selectNodeContents(dom3); //将选中节点的内容放到range对象中去
dom3.appendChild(rangeObj.cloneContents()); //选中节点追加到dom里面 }

rangeObj.extractContents();//移除当前节点的内容并返回内容

<div id="clone_4" style="width:400px;height:100px; background:red;color:#fff;line-height:50px;">被复制的节点</div>
<div id="clone_5" style="width:400px;height:100px; background:blue;color:#fff;line-height:50px;"></div>
<button onclick="range_clone3()">克隆内容</button> function range_clone3(){
var dom4=document.getElementById('clone_4');
var dom5=document.getElementById('clone_5');
var rangeObj=document.createRange(); //创建一个range对象
rangeObj.selectNodeContents(dom4); //将选中节点的内容放到range对象中去
dom5.appendChild(rangeObj.extractContents()); //移除当前节点的内容并返回内容
         }

四、插入节点

rangeObj.insertNode(node);

<div>
<p onmouseup="insert_node()">啊实打实大声道爱迪生的骄傲是啊实打实大师第按时打算开大声点阿达撒打算带上的安顺地阿斯蒂速度打死对岸是爱的搜读搜到啊实打实短视的案时段是对阿萨德安顺地阿斯打算爱上帝啊索敌爱上丢死殴打安顺地阿斯打算的爱上帝啊手段是偶的按时到你说的</p>
<button id="insert_btn" >移动插入node</button>
</div>

 function insert_node(){
/*var childList=insert_node.childNodes;
for (var i = 0; i < childList.length; i++) {
console.log(childList.item(i));
};*/
var insert_btn=document.getElementById("insert_btn");
var selection=document.getSelection(); //获取选中区域对象
if(selection.rangeCount){ //获取选中区域的个数
var range=selection.getRangeAt(0); //获取range对象
range.insertNode(insert_btn); //使用range方法插入dom节点
}
}

五、rangeObj.collapse() 取消选中节点

collapse.insertNode(node);
var rangeObj=document.createRange();
function getRange(){
var dom_div=document.getElementById('getRange');
rangeObj.selectNodeContents(dom_div);
} function cancleRange(){
rangeObj.collapse(false);
} function showRange(){
alert(rangeObj.toString());
} </script>
<div id="getRange">选中的内容</div>
<button onclick="getRange()">获取选中节点</button>
<button onclick="cancleRange()">取消选中节点</button>
<button onclick="showRange()">显示选中节点</button>

六、rangeObj.detach()  释放range对象

HTML5 页面编辑API之Range对象的更多相关文章

  1. HTML5编辑API之Range对象

    Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改页面上的任何区域,可以通过如下创建一个空的Range对象,如下: var  range = document.createRa ...

  2. [html5] 学习笔记-编辑 API 之 Range 对象(一)

    1.Range对象的基本概念 一个Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改网页上的任何区域. <!DOCTYPE html> <html> & ...

  3. HTML5 编辑 API 之 Range 对象(一)

     一.Range 对象基本概念 通过使用 Range 对象所提供的方法实现一个鼠标选取内容,通过点击按钮打印出选中内容,当然注意在不同的浏览器下可选中的内容数量是不同的. <!DOCTYPE h ...

  4. [html5] 学习笔记- 编辑API之Range对象(二)

    本节继续介绍range对象的方法,包括cloneRange,cloneContents,extraContents,createContextual,createContextual-Fragment ...

  5. HTML5 编辑 API 之 Range 对象(二)

    1.Range.cloneContents()The Range.cloneContents() returns a DocumentFragment copying the objects of t ...

  6. [H5]API之range对象

    range对象:是一种fragment(HTML片断),它包含了节点或文本节点的一部分.一般情况下,同一时刻页面中只可能 有一个range,也有可能是多个range(使用Ctrl健进行多选,不过有的浏 ...

  7. web前端学习(二)html学习笔记部分(3)--range对象

    1.2.8  html5编辑api之range对象(一) 1.2.8.1  Range 对象基本概念 Range 对象的基本概念,通过使用 Range 对象所提供的方法实现一个鼠标选取内容,通过点击按 ...

  8. HTML5中的Range对象的研究

    一:Range对象的概念 Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改页面上的任何区域,可以通过如下创建一个空的Range对象,如下: var  range = docu ...

  9. HTML5中的Range对象的研究(转载)

    一:Range对象的概念 Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改页面上的任何区域,可以通过如下创建一个空的Range对象,如下: var  range = docu ...

随机推荐

  1. 微信小程序 Button控件 点击传值给JavaScript

    直接看例子吧: WXML:直接看Button,用“data-”(data-total)传值,后台如何获取,继续看下面JS代码. <view class="infothird" ...

  2. OpenCV3编程入门-读书笔记2-core组件

    一.颜色空间缩减 1.概念 如果图像是3通道,深度为1个字节,则每个像素有256*256*256种可能值,这么多的可能值会对算法性能造成严重影响.利用颜色空间缩减就能解决这个问题,例如将颜色值0~9取 ...

  3. 在js中插入html语句

    连上数据库之后,填充数据时往往需要在js中插入html语句 做法是: <body> <div class="modal-body" id="delete ...

  4. java中对象的创建过程

    public class Test1 { public static void main(String[] args) { new B(); System.out.println("---- ...

  5. 精通ArrayList,关于ArrayList你想知道的一切

    目录 精通ArrayList,关于ArrayList你想知道的一切 前言 ArrayList 内部结构,和常用方法实现 实例化方法 添加元素 add()方法 get()方法 移除元素 怎么扩容的 序列 ...

  6. 【原创】C# war3 巨魔精灵 minimap

    弃坑LOL后,无聊的时候玩玩 war3的RPG地图,巨魔与精灵.  玩了一段时间精灵....然后玩魔结果总是找不到人.所以就有了这个想法. 代码纯粹靠搬运. 说下原理,网上有份代码,可以查看当前选中目 ...

  7. Codeforces 513D2 Constrained Tree

    Constrained Tree 没写出来好菜啊啊. 首先根据输入我们能算出某些节点的左儿子的范围, 右儿子的范围(此时并不准确) 然后我们在划分u这个节点的时候我们从左右开始用树状数组check每一 ...

  8. P1991 无线通讯网 最小生成树

    题目描述 国防部计划用无线网络连接若干个边防哨所.2 种不同的通讯技术用来搭建无线网络: 每个边防哨所都要配备无线电收发器:有一些哨所还可以增配卫星电话. 任意两个配备了一条卫星电话线路的哨所(两边都 ...

  9. 辅助排序和Mapreduce整体流程

    一.辅助排序 需求:先有一个订单数据文件,包含了订单id.商品id.商品价格,要求将订单id正序,商品价格倒序,且生成结果文件个数为订单id的数量,每个结果文件中只要一条该订单最贵商品的数据. 思路: ...

  10. HDU 5984.Pocky(2016 CCPC 青岛 C)

    Pocky Let’s talking about something of eating a pocky. Here is a Decorer Pocky, with colorful decora ...