简介

selection是对当前激活选中区(即高亮文本)进行操作。

在非IE浏览器(Firefox、Safari、Chrome、Opera)下可以使用window.getSelection()获得selection对象,本文讲述的是标准的selection操作方法。文中绝大部分内容来自 https://developer.mozilla.org/en/DOM/Selection

术语

以下几个名词是英文文档中的几个名词。

anchor
选中区域的“起点”。
focus
选中区域的“结束点”。
range
是一种fragment(HTML片断),它包含了节点或文本节点的一部分。一般情况下,同一时刻页面中只可能有一个range,也有可能是多个range(使用Ctrl健进行多选,不过有的浏览器不允许,例如Chrome)。可以从selection中获得range对象,也可以使用document.createRange()方法获得。

属性

anchorNode
返回包含“起点”的节点。
anchorOffset
“起点”在anchorNode中的偏移量。
focusNode
返回包含“结束点”的节点。
focusOffset
“结束点”在focusNode中的偏移量。
isCollapsed
“起点”和“结束点”是否重合。
rangeCount
返回selection中包含的range对象的数目,一般存在一个range,Ctrl健配合使用可以有多个。

方法

getRangeAt(index)
从当前selection对象中获得一个range对象。
index:参考rangeCount属性。
返回:根据下标index返回相应的range对象。
collapse(parentNode, offset)
将开始点和结束点合并到指定节点(parentNode)的相应(offset)位置。
parentNode:焦点(插入符)将会在此节点内。
offset: 取值范围应当是[0, 1, 2, 3, parentNode.childNodes.length]。

  • 0:定位到第一个子节点前。
  • 1:第二个子节点前。
  • ……
  • childNodes.length-1:最后一个子节点前。
  • childNodes.length:最后一个子节点后。

Mozilla官方文档 中讲到取值为0和1,经测试不准确。文档中还有一句不是十分清楚“The document is not modified. If the content is focused and editable, the caret will blink there.”

extend(parentNode, offset)
将“结束点”移动到指定节点(parentNode)的指定位置(offset)。
“起点”不会移动,新的selection是从“起点”到“结束点”的区域,与方向无关(新的“结束点”可以在原“起点”的前面)。
parentNode:焦点将会在此节点内。
Offset:1,parentNode的最后;0,parentNode的最前。
modify(alter, direction, granularity)
改变焦点的位置,或扩展|缩小selection的大小
alter:改变的方式。”move”,用于移动焦点;”extend”,用于改变selection。
direction:移动的方向。可选值forward | backword或left | right
granularity:移动的单位或尺寸。可选值,character", "word", "sentence", "line", "paragraph", "lineboundary", "sentenceboundary", "paragraphboundary", or "documentboundary"。
Firefox 4 / Thunderbird 3.3 / SeaMonkey 2.1才会支持此函数, 官方文档: https://developer.mozilla.org/en/DOM/Selection/modify
collapseToStart()
将“结束点”移动到,selction的“起点”,多个range时也是如此。
collapseToEnd()
将“起点”移动到,selction的“结束点”,多个range时也是如此。
selectAllChildren(parentNode)
将parentNode的所有后代节点(parentNode除外)变为selection,页面中原来的selection将被抛弃。
addRange(range)
将range添加到selection当中,所以一个selection中可以有多个range。
注意Chrome不允许同时存在多个range,它的处理方式和Firefox有些不同。
removeRange(range)
从当前selection移除range对象,返回值undefined。
Chrome目前没有改函数,即便是在Firefox中如果用自己创建(document.createRange())的range作为参数也会报错。
如果用oSelction.getRangeAt()取到的,则不会报错。
removeAllRanges()
移除selection中所有的range对象,执行后anchorNode、focusNode被设置为null,不存在任何被选中的内容。
toString()
返回selection的纯文本,不包含标签。
containsNode(aNode, aPartlyContained)
判断一个节点是否是selction的一部分。
aNode:要验证的节点。
aPartlyContained:true,只要aNode有一部分属于selection就返回true;false,aNode必须全部属于selection时才返回true。

document.activeElement

该属性属于HTML5中的一部分,它返回当前获得焦点的元素,如果不存在则返回“body”。一般情况下返回的是“文本域”或“文本框”。也有可能返回“下拉列表”、“按钮”、“单选”或“多选按钮”等等,Mac OS系统中可能不会返回非输入性元素(textbox,例如文本框、文本域)。

相关属性和方法:

selectionStart
输入性元素selection起点的位置,可读写。
selectionEnd
输入性元素selection结束点的位置,可读写。
setSelectionRange(start, end)
设置输入性元素selectionStart和selectionEnd值
  • 如果textbox没有selection时,selectionStart和selectionEnd相等,都是焦点的位置。
  • 在使用setSelectionRange()时
    如果end小于start,会讲selectionStart和selectionEnd都设置为end;
    如果start和end参数大于textbox内容的长度(textbox.value.length),start和end都会设置为value属性的长度。
  • 值得一提的是selectionStart和selectionEnd会记录元素最后一次selection的相关属性,意思就是当元素失去焦点后,使用selectionStart和selectionEnd仍能够获取到元素失去焦点时的值。这个特性可能会对制作“插入表情”时十分有用(将表情插入到元素最后一次焦点的位置)。
<textarea id="textbox">abc中国efg</textarea>
<script type="text/javascript">
window.onload = function(){var textbox = document.getElementById('textbox');textbox.setSelectionRange(5, 2);console.log(textbox.selectionStart);    // 2console.log(textbox.selectionEnd);      // 2
};
</script>
<textarea id="textbox">abc中国efg</textarea>
<script type="text/javascript">
window.onload = function(){var textbox = document.getElementById('textbox');textbox.setSelectionRange(9, 9);console.log(textbox.selectionStart);    // 8console.log(textbox.selectionEnd);      // 8
};
</script>

支护性:ie6\7\8不支持;Chrome、Firefox、Opera、Safari都支持。

参考文档:https://developer.mozilla.org/en/DOM/document.activeElement

document.designMode = 'on';

当document.designMode = 'on'时selection的方法、selectionStart、selectionEnd在Firefox和Opera中不可以使用,但Chrome和Safari可以。

document.selection相关推荐

  1. DHTML之-----document.selection 的 createRange

    一.document.selection 介绍 document.selection 表示当前网页中的选中内容. 方法有: clear 清除选中的内容 empty 取消选中 createRange 返 ...

  2. document.selection.createRange方法

    document.selection.createRange() 根据当前文字选择返回 TextRange 对象,或根据控件选择返回 ControlRange 对象. 配合 execCommand,在 ...

  3. 关于document.selection和TextRange对象的介绍

    document.selection只有IE支持 window.getSelection()也只有FireFox和Safari支持,都不是标准语法. selection 对象代表了当前激活选中区,即高 ...

  4. Document对象内容集合

    document 文挡对象 - JavaScript脚本语言描述 ------------------------------------------------------------------- ...

  5. JS的Document属性和方法

    document.title //设置文档标题等价于HTML的title标签 document.bgColor //设置页面背景色 document.fgColor //设置前景色(文本颜色) doc ...

  6. JavaScript window.document的属性、方法和事件小结

    javascript中window.document的属性.方法和事件的总结,有需要的朋友可参考一下本文章. 属性: Attributes 存储节点的属性列表(只读) childNodes 存储节点的 ...

  7. document 文挡对象解析

    日后整理-- 对象属性: document.title //设置文档标题等价于HTML的<title>标签 document.bgColor //设置页面背景色 document.fgCo ...

  8. document 文挡对象 - JavaScript脚本语言描述

    document 文挡对象 - JavaScript脚本语言描述 ------------------------------------------------------------------- ...

  9. Document builder customizing

    Created by Jerry Wang on Jun 29, 2014 Define element type: 定义element在文档中的逻辑作用: define text type: def ...

最新文章

  1. JS如何捆绑TypeScript声明文件
  2. MySQL系列(二)
  3. .net中用Action等委托向外传递参数
  4. 云平台已经成为发生网络攻击的重灾区
  5. xp服务器文档在哪里,如何在XP系统中创建文件服务器
  6. cypress 的错误消息 - the element has become detached or removed from the dom
  7. drools 决策表_骆驼和春天的Drools决策表
  8. windows服务器网站日志,windows服务器网站日志文件
  9. 数据结构与算法——选择排序
  10. javamail腾讯企业邮箱发送邮件
  11. Java 操作 JSON
  12. 英语语法笔记--定语从句及同位语从句
  13. Python提取Word文档中所有脚注文本
  14. 第十章《日期与时间》第6节:ZoneId、ZoneRegion和ZoneOffset
  15. 转载--三少三多技术开发
  16. 迅雷极速版阻止自动更新(亲自摸索出来,可用)
  17. python 对比matlab_全面对比 MATLAB、Julia、Python,谁在科学计算中更胜一筹?
  18. 《传奇之王》风波不断 编剧替柳云龙打抱不平_0
  19. 探花交友_第7章-完善消息功能以及个人主页
  20. 语音处理/语音识别基础(二)- 声音的存储

热门文章

  1. 怎么就管不住这手!APP让人上瘾的秘密
  2. 《微SaaS创富周刊》第7期:Gmail插件创富 | 20+项目盘点、GMass月收20万的秘笈
  3. N1盒子刷入openwrt并部署青龙面板
  4. 手机上如何压缩PDF文件大小
  5. selenium跳过webdriver检测并模拟登录淘宝
  6. Excuse me?!32年万家乐“焕新”为人气担当,自带流量刷爆上海厨博会!
  7. 在南宁读书的第一次外出游玩记
  8. 做一名开源社区扫地僧(转)
  9. 有哪些值得推荐的电脑录屏软件与手机录屏软件?
  10. 抖音APP双击点赞效果实现