操作范围中的内容

在创建范围时,内部会为这个范围创建一个文档片段

范围所属的全部节点都会被添加到这个片段中

虽然选取范围可以不是完整的、良好的DOM结构

但是在这个为范围创建的文档片段中,会自己完缺少的闭合标签,以此构建有效的DOM结构来方便我们操作

上述步骤都是内部实现的,因此我们可以不用过多地关注这一方面

首先是 deleteContents()

这个方法会从文档中删除选中范围的内容

以下方的HTML代码为例

<p id = "p1"><b>hello</b>world!</p>

使用deleteContents()方法:

var p1 = document.getElementById("p1");
var helloNode = p1.firstChild.firstChild;
var worldNode = p1.lastChild;
var range = document.createRange(); range.setStart(helloNode,2);
range.setEnd(worldNode,3); range.deleContents();

此后文档中的内容如下

<p id = "p1"><b>he</b>rld!</p>

由于在底层实现中JS会自动完整没有闭合的标签,所以能保有一个良好的文档结构

然后就是 extractContents()方法

这个方法和 delete Contents()方法一样都会从文档中移除范围内容

但是有所区别

这个方法会返回被移除的范围中的内容

此外 cloneContents() 方法用于复制范围中的节点

和 extractContents() 一样都会返回节点,只不过这里返回的不是实际节点

而是实际节点的副本

我们可以使用 appendChild()方法将其重新插入文档中

PS.在调用上述的操作范围的方法之前,范围中的内容并不会产生格式良好的文档片段

向范围中插入内容

首先是 insertNode()方法,可以向范围的开始处插入一个节点

例如:

var p1 = document.getElementById("p1");
var helloNode = p1.firstChild.firstChild;
var worldNode = p1.lastChild;
var range = document.createRange(); range.setStart(helloNode,2);
range.setEnd(worldNode,3); var span = document.createElement("span");
span.style.color = "red";
span.appendChild(document.createTextNode("Inserted text"));
range.insertNode(span);

运行后会得到以下文档结构

<p id = "p1"><b>he<spand style="color:red">Interted text</span>llo</b>world!</p>

此外还有一个方法 surroundContents()用于环绕范围插入内容

一般来说用于为范围添加特殊样式

折叠DOM范围

折叠是指范围没有选中内容的情况,就相当于用鼠标选择文字时的光标竖线一样

该情况储存在range 的 collapsed 属性中

range.collapsed

可以用于判断两个节点十分紧密相邻

比较范围

在有多个范围的情况下,可以使用 compareBoundaryPoints()方法来确定范围是否有公共边界

该方法接收两个参数:

  1. 表示比较方式的常量:
    1. Range.START_TO_START(0) 比较两个范围的起点
    2. Range.START_TO_END(1) 比较第一个起点和第二个终点
    3. Range.END_TO_END(2); 比较两个范围的终点
    4. Range.END_TO_START(3) 比较第一个终点和第二个起点
  2. 要比较的范围

该方法对于第一个点在第二个比较的点之前返回-1

两个点相同返回 0

第一个在第二个之后返回1

其它

复制DOM范围

var newRange = range.cloneRange();

清理DOM范围

range.detach();//从文档中分离
range = null;//解除引用

    

Javascript高级编程学习笔记(55)—— DOM2和DOM3(7)操作范围的更多相关文章

  1. Javascript高级编程学习笔记(82)—— 富文本操作(2)

    操作富文本 与富文本编辑器的交互的主要方式就是使用 document.execCommand() 方法 该方法可以对文档执行自定义命令,并且可以应用大多数格式 该方法接收三个参数: 要执行命令的名称 ...

  2. Javascript高级编程学习笔记(49)—— DOM2和DOM3(1)DOM变化

    DOM变化 我们知道DOM有许多的版本,其中DOM0和DOM2这两个级别以对事件的纳入标准而为人所知 但是呢,这里不讲事件,在后面会有专门和事件有关的部分作为详细讲解 这里就只讲一下DOM2和DOM3 ...

  3. Javascript高级编程学习笔记(1)—— JS简介

    此系列文章,用于记录所学,如有错误欢迎指出. Javascript组成 1.核心(ECMAScript) 2.文档对象模型(DOM) 3.浏览器对象模型(BOM) 1.核心(ECMAScript) E ...

  4. Javascript高级编程学习笔记(53)—— DOM2和DOM3(5)遍历

    遍历 “DOM2级遍历和范围” 定义了两个用于辅助完成顺序遍历的DOM结构类型 NodeIterator 和 TreeWalk 上述两种类型可以基于给定起点的DOM结构执行深度优先的遍历操作 对于检测 ...

  5. Javascript高级编程学习笔记(54)—— DOM2和DOM3(6)范围选择

    范围 为了让开发人员更加方便地控制页面“DOM2级遍历和范围”模块定义了“范围”接口 通过该接口开发人员可以选择文档中的一个区域,而不必考虑元素的界限 在常规操作不能有效地修改文档时,使用范围往往可以 ...

  6. Javascript高级编程学习笔记(52)—— DOM2和DOM3(4)元素大小

    在日常实践中,我们在使用JS的时候难免会需要获取元素的大小及位置 首先要声明的是,这一部分的内容并不属于DOM2样式规范,因为DOM中并没有对我们如何获取元素大小的相关信息做出规范 偏移量 偏移量及元 ...

  7. Javascript高级编程学习笔记(50)—— DOM2和DOM3(2)样式

    样式 在HTML中定义元素的方式有以下三种: 1.link标签引入外部样式表 2.style标签定义嵌入样式 3.通过JS中对style特性定义元素样式(行内样式) “DOM2级样式”围绕上述样式机制 ...

  8. Javascript高级编程学习笔记(56)—— DOM2和DOM3(8)低版本IE范围

    虽然IE9支持了DOM范围,但是IE8及更早版本并不支持DOM范围 所以IE8以下的更早版本的IE提出了与之类似的概念以供大家使用 也就是 文本范围 var range = document.body ...

  9. Javascript高级编程学习笔记(51)—— DOM2和DOM3(3)操作样式表

    操作样式表 在JS中样式表用一种类型来表示,以便我们在JS对其进行操作 这一类型就是CSSStyleSheet 即CSS样式表类型,包括了之前 style 对象所不包括的外部样式表以及嵌入样式表 其中 ...

随机推荐

  1. docker-compose安装

    安装docker-compose两种最新的docker安装方式 1.从github上下载docker-compose二进制文件安装下载最新版的docker-compose文件 $ sudo curl ...

  2. Spring+Quartz集群环境下定时调度的解决方案

    集群环境可能出现的问题 在上一篇博客我们介绍了如何在自己的项目中从无到有的添加了Quartz定时调度引擎,其实就是一个Quartz 和Spring的整合过程,很容易实现,但是我们现在企业中项目通常都是 ...

  3. 机器学习入门-BP神经网络模型及梯度下降法-2017年9月5日14:58:16

    BP(Back Propagation)网络是1985年由Rumelhart和McCelland为首的科学家小组提出,是一种按误差逆传播算法训练的多层前馈网络,是目前应用最广泛的神经网络模型之一. B ...

  4. centos 下使用vscode 调试egg.js 注意事项

    这两天在centos下,直接用vscode运行egg.js的例子.遇到个问题就是当安装了vscode-egg插件,会遇到一个现象.就是同样的代码,Windows下调试可以顺利进行,但是centos有时 ...

  5. 51ak带你看MYSQL5.7源码4:实现SQL黑名单功能

    博客迁移至: https://www.dboop.com/ 从事DBA工作多年 MYSQL源码也是头一次接触 尝试记录下自己看MYSQL5.7源码的历程 申明:个人Python编程很溜,但是C++还停 ...

  6. 25. pt-slave-restart

    pt-slave-restart -h 192.168.100.103 -P 3306 -u admin -p admin \--error-numbers 1032 set global slave ...

  7. jmeter安装与使用

    1.下载安装Jmeter.JDK Jmeter官网下载地址: http://jmeter.apache.org/download_jmeter.cgi JDK官网下载地址: http://www.or ...

  8. 【转载】http proxy原理

    最近使用Charles抓https包时,发现get和post方式的请求都能抓到,但是method为connect的就是抓不到.而且提示如下: You may need to configure you ...

  9. 由odoo源不稳定想到的,一个非常简单但是有效的方式解决yum源不稳定的问题,实现无限重试

    如题,最近在安装odoo 10, 但是官方源的速度是在是不敢恭维,断断续续的. yum 有没有能够无限重试的参数,于是用python写了个死循环,让它无限重试下去 脚本如下: #! /usr/bin/ ...

  10. strncpy

    char* mstrncpy(char *dest, const char *src, size_t n){ size_t i; size_t j=n-; ; i < j && ...