处理文本部分内容的TextRange对象应用实例


Posted in Javascript onJuly 29, 2014

因用户要求方与TextRange对象结缘,用于处理JavaScript对象文本部分内容的一个对象。

TextRange是用来表现HTML元素中文字的对象,虽然我们平时不太常用这个对象,可是它却在IE4.0中就已提供了。不过TextRange提供的调用方法却都比较晦涩,那么我们能拿它做些什么呢?
TextRange的传统用途是对用户在Web页上用鼠标圈选的文字内容的操作,比如变化、删除、新增等。但其经典的用途却是,在Web页面中查找文字(这个比较简单)和获取输入框光标的位置。其中后者又有可以衍生出很多更有用的用途,比如:限制输入的MaskTextBox,其核心技术点就是获取输入框的光标位置,然后使用正则表达式判断输入内容。还有我后面会介绍的"使用方向键在输入框矩阵中自然的导航",核心技术点也是获取输入框中的光标位置。

获取输入框中的光标位置的整个代码其实很短,只是这些对象和方法不太常用而已。

Js代码

<span style="font-size: medium;"><script language="javascript"> 

function GetCursorPsn(txb) 

{ 

var slct = document.selection; 

var rng = slct.createRange(); 

txb.select(); 

rng.setEndPoint("StartToStart", slct.createRange()); 

var psn = rng.text.length; 

rng.collapse(false); 

rng.select(); 

return psn; 

} 

</script></span>

这里说一下使用这个GetCursorPsn()方法后,会给输入框操作带来的副作用。

对于输入框

Html代码

<span style="font-size: medium;"><input type="text" onkeydown="GetCursorPsn(this)"></span>

它将不能再使用Shift+左右这两个方向键来选择文本;对于

Html代码

<span style="font-size: medium;"><textarea onkeydown="GetCursorPsn(this)"></textarea></span>

,将不能再使用Shift+上下左右四个方向键来选择文本。因为代码在获取了当前光标到文本的startPoint后,调用rng.collapse(false );会 改变文本筐内文本的EditPoint。

1、满足用户要求代码片段,使用上下左右四个键实现文本框的跳转,同时选择其文本框内容,从而方便用户修改,代码如下:

Js代码

<span style="font-size: medium;">var range = $currentTextfield.createTextRange();//$currentTextfield为jQuery对象 

range.moveStart('character',0); 

range.select();</span>

以下是舶来的一片个人感觉还算不错的关于TextRange的文章:

Html代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 

<html xmlns="http://www.w3.org/1999/xhtml"> 

<head> 

<title> new document </title> 

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 

<style> 

body { font-size:12px; } 

#show { background-color:#CCFF99; } 

</style> 

</head> 

<body> 

<textarea id="content" cols="30" rows="10"> 

河中鱼类离奇死亡,下游居民频染怪病,沿岸植物不断变异,是残留农药?还是生化攻击?敬请关注今晚CCTV-10《科学探索》,即将播出的专题节目:《神秘的河边洗脚人--中国男足》 

</textarea> 


<button id="btn">获取选中值</button> 

<div id="show"></div> 

<script> 

String.prototype.trim = function() { 

return this.replace(/^\s+|\s+$/g, ""); 

} 

/* 方法一 FF下有点问题 */ 

function getSelectText() { 

try{ 

// IE: document.selection.createRange() W3C:window.getSelection() 

var selectText = (document.selection && document.selection.createRange )? document.selection.createRange().text : window.getSelection().toString(); 

if(selectText != null && selectText.trim() != ""){ 

return selectText; 

} 

}catch(err){} 

} 

/* 方法二 */ 

function getSelectText2(id) { 

var t = document.getElementById(id); 

if(window.getSelection) { 

if(t.selectionStart != undefined && t.selectionEnd != undefined) { 

return t.value.substring(t.selectionStart, t.selectionEnd); 

} else { 

return ""; 

} 

} else { 

return document.selection.createRange().text; 

} 

} 

document.getElementById('btn').onclick = function() { 

document.getElementById('show').innerHTML = getSelectText2('content'); 

} 

</script> 

</body> 

</html>
Javascript 相关文章推荐
跨域表单提交状态的变相判断代码
Nov 12 Javascript
javascript 通用简单的table选项卡实现
May 07 Javascript
IE和Firefox的Javascript兼容性总结[推荐收藏]
Oct 19 Javascript
2014年最火的Node.JS后端框架推荐
Oct 27 Javascript
分享十五款 jQuery 社交网络分享插件
May 16 Javascript
基于vuejs+webpack的日期选择插件
May 21 Javascript
jQuery的事件预绑定
Dec 05 Javascript
Angular1.x复杂指令实例详解
Mar 01 Javascript
jQuery.Sumoselect插件实现下拉复选框效果
Nov 09 jQuery
使用vuex缓存数据并优化自己的vuex-cache
May 30 Javascript
Vue侦测相关api的实现方法
May 22 Javascript
Vue2.X和Vue3.0数据响应原理变化的区别
Nov 07 Javascript
js键盘事件的keyCode
Jul 29 #Javascript
js识别不同浏览器基于userAgent做判断
Jul 29 #Javascript
让浏览器DOM元素最后加载的js方法
Jul 29 #Javascript
js实现遮罩层划出效果是生成div而不是显示
Jul 29 #Javascript
解释&amp;&amp;和||在javascript中的另类用法
Jul 28 #Javascript
wap手机图片滑动切换特效无css3元素js脚本编写
Jul 28 #Javascript
jQuery内置的AJAX功能和JSON的使用实例
Jul 27 #Javascript
You might like
PHP入门速成教程
2007/03/19 PHP
通过JavaScript或PHP检测Android设备的代码
2011/03/09 PHP
基于PHP选项与信息函数的使用详解
2013/05/10 PHP
在Laravel 的 Blade 模版中实现定义变量
2019/10/14 PHP
详解PHP中的8个魔术常量
2020/07/06 PHP
Auntion-TableSort国人写的一个javascript表格排序的东西
2007/11/12 Javascript
javascript模拟实现ajax加载框实例
2014/10/15 Javascript
AngularJS中取消对HTML片段转义的方法例子
2015/01/04 Javascript
使用jQuery获得内容以及内容的属性
2015/02/26 Javascript
angularjs实现天气预报功能
2020/06/16 Javascript
js实现贪吃蛇游戏 canvas绘制地图
2020/09/09 Javascript
[01:36:57]【09DOTA2第一视角】小骷髅
2014/04/16 DOTA
[01:46]辉夜杯—打造中国DOTA新格局
2015/12/25 DOTA
python实现网页链接提取的方法分享
2014/02/25 Python
详解Python中for循环的使用
2015/04/14 Python
Python编写生成验证码的脚本的教程
2015/05/04 Python
浅谈Python中数据解析
2015/05/05 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
对python 各种删除文件失败的处理方式分享
2018/04/24 Python
python线程中同步锁详解
2018/04/27 Python
用Python实现二叉树、二叉树非递归遍历及绘制的例子
2019/08/09 Python
扩展Django admin的list_filter()可使用范围方法
2019/08/21 Python
Python制作词云图代码实例
2019/09/09 Python
举例详解HTML5中使用JSON格式提交表单
2015/06/16 HTML / CSS
详解canvas绘制多张图的排列顺序问题
2019/01/21 HTML / CSS
美国折衷生活方式品牌:Robert Graham
2018/07/13 全球购物
英国最大的纸工艺品商店:CraftStash
2018/12/01 全球购物
美国Curacao百货连锁店网站:iCuracao.com
2019/07/20 全球购物
YSL圣罗兰美妆俄罗斯官网:Yves Saint Lauret RU
2020/09/23 全球购物
软件测试企业面试试卷
2016/07/13 面试题
业务员岗位职责
2013/11/16 职场文书
产品销售员岗位职责
2013/12/18 职场文书
幼儿园中班新学期寄语
2014/01/18 职场文书
辞职信格式模板
2015/02/27 职场文书
辩论赛主持人开场白
2015/05/29 职场文书
Python深度学习之实现卷积神经网络
2021/06/05 Python