`
zhangyaochun
  • 浏览: 2626720 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

首发-----凤凰前端脚本库之光标操作

阅读更多

以前就一直研究jQuery和prototype,从到百度这个来工作开始就一直研究tangram,从那会开始就一直想自己慢慢地积累写一个Lib(以前参与写过一个公司级的toft,情节啊),当然原因只是积累和学习,建议所有前端人士如果你有毅力的话可以自己整理写一个lib,因为在你写的时候,你会发现各种问题,然后你会查阅资料去解决这些问题,这样的提升比你简单地去使用api要好很多。

 

废话少说,今天贴出的只是最近整理的关于光标的一些api的处理,简单地上传,供各位同学一起学习研究。

 

 

/*
****   phoenix lib    version 1.0.1 ****
@author zhangyaochun 
@just for 87
@baidu fe
@个人博客--http://zhangyaochun.iteye.com/
@info 简单地介绍一下这个库--凤凰
1.what is phoenix---它是本人学习积累的一个库,部分思想来源tangram,prototype,jquery等一些开源框架,采用分离式api设计,没有绝对的核心
2.这个库的目标:第一目标是兼容性-----保证兼容各大浏览器,简单地说就是能用
                第二目标是可读性-----保证看到这个库的人能从里面看明白一些东西,从而选择你所需的
                下面就是api设计的一致性和前瞻性还有简单性是日后一直追求的
				有部分安全性防范的api设计理念,防止代码白跑
3.优化思想		有作用域链的优化思想
				独立命名空间下的功能模块,防污染
************************************************************************************************
   phoenix.textareaUtil.js这个主要是对于光标的一些操作
   api简介:1. getCursorPosition-----获取当前光标的位置
           2. getSelectedText-------获取选中的文本
		   3. setSelection----------选中一个指定区间的文本
		   4. setCursorPosition-----设置光标的到达指定位置
		   5. setSelectionText------选中一个指定的文本
		   6. deleteText------------删除光标前后的指定个字符
*/
var phoenix =phoenix || {version:'1.0.1'};

phoenix.textareaUtil = phoenix.textareaUtil || {};

//后期考虑做快捷方式的调用优化,可读性的杀手啊

/*
获取当前光标的位置
@Method getCursorPosition
@param {HTMLElement}  --element  绑定的textarea对象
@return {Number}  ---result  当前光标的位置
@remark 约定当前没有光标就返回0
 ff和opera下如果文本区域没有光标返回的是value.length
 chrome和ie是0
*/
phoenix.textareaUtil.getCursorPosition = function(element){
   var result =0;
	//处理兼容
   if(document.selection){
     //ie
	 element.focus();
	 var ds = document.selection
	 var range = ds.createRange();
	 var g = range.duplicate();
	 g.moveToElementText(element);
	 g.setEndPoint("EndToEnd",range);
	 element.selectionStart = g.text.length - range.text.length;
	 element.selectionEnd = element.selectionStart +range.text.length;
	 result = element.selectionStart;
   }else{
     //ff-chrome-opera
	 //加层判断
	 if(element.selectionStart || element.selectionStart == "0"){
	    //ff和opera多是element.value.length
		//chrome
		result = element.selectionStart;
	 }
   }
   return result;
},


/*
获取选中的文本
@Method getSelectedText
@param {HTMLElement}   ---element
@return {String} | "" ---result
@remark 约定如果没有选中返回""
*/
phoenix.textareaUtil.getSelectedText = function(element){
    var result="";
	var find = function(el){
	   if(el.selectionStart != undefined && el.selectionEnd != undefined){
	      return el.value.slice(el.selectionStart,el.selectionEnd);
	   }else{
	      return "";
	   }
	}
	if(window.getSelection){
	   //ff-chrome-opera
	   result = find(element);
	}else{
	   //ie
	   result = document.selection.createRange().text;
	}
	return result;
},



/*
选中从start到end之间的文本
@Method setSelection 
@param {HTMLElement}  --element
@param {Number}  ---start index
@param {Number}    ---end index
*/
phoenix.textareaUtil.setSelection = function(element,start,end){
     if(document.selection){
	     var range = element.createTextRange();
		 range.moveEnd('character',end-element.value.length);
		 range.moveStart('character',start);
		 range.select();
	 }else{
	     element.setSelectionRange(start,end);
		 element.focus();
	 }
},


/*
设置光标的到达指定位置
@Method setCursorPosition 
@param e{HTMLElement}  --element
@param pos{Number}  ---position
@remark 这个api依赖于setSelection
*/
phoenix.textareaUtil.setCursorPosition = function(element,pos){
   this.setSelection(element,pos,pos);
},


/*
选中一个指定的文本
@Method setSelectionText also can call findText
@param {HTMLElement}  ---element
@param  {String} ---- string
@return index
@remark 这个api依赖于setSelection
    if no find return false
*/
phoenix.textareaUtil.setSelectionText = function(element,string){
     var index = element.value.indexOf(string);
	 return index!= -1 ? this.setSelection(element,index,index+string.length) : false;
},

/*
删除光标前后的指定个字符
@Method deleteText
@param {HTMLElement} element
@param number {Number} 删除前后的number个字符
@remark if number >0  删除前面number个字符 反之
@remak 解决兼容性问题存在的bug ---发生场景
                              1.是有滚动条---先记录后针对ff进行setTimeout复制 ---ff最新的版本已经没有这个问题了
                              2.如果光标前面没有可删除的 ---由于slice自身的api设置参数end如果为负会返回string.length +end
							  但是substring又不支持参数为负,暂时采用
	***思考:如果当前光标就在第一位,其实可以return false---对用户的效果是一样的,而且代码不必要走***						  
*/
phoenix.textareaUtil.deleteText = function(element,number){
    var scrolTop = element.scrollTop;  //记录旧的scrollTop 针对ff的bug
    var curpos = this.getCursorPosition(element);   //当前光标的位置
	var val = element.value;     //textarea输入的值
	//改变删除后的文本值
	//当curpos为0的话 会由于slice的自身原因返回错误(如上注释)
	/*element.value = number > 0 ? val.slice(0,curpos - number) + val.slice(curpos) :
	                             val.slice(0,curpos) + val.slice(curpos - number);*/
    //测试后暂时先用这个substring(0,-2)后会返回"",不会像slice一样slice(0,-2)变成slice(0,string.length-2);	 
	 element.value = number > 0 ? val.substring(0,curpos - number) + val.substring(curpos) :
	                             val.substring(0,curpos) + val.substring(curpos - number);							 
    //直接走-- 控制光标的位置
	//ff下Bug是在出现滚动条的时候删除文字后scrollTop会自动置0
	//ie下Bug是删除之后的光标计算有问题
	this.setSelection(element, curpos-(number <0 ? 0 : number),curpos-(number <0 ? 0 : number));
	//console.log(scrolTop);
	//处理一下ff的scrollTop为0的bug(ff的最新版本已经没有这个问题了)
	var isFf= /firefox\/(\d+\.\d+)/i.test(navigator.userAgent) ? +RegExp['\x241']: undefined;
	if(isFf != undefined){
	   setTimeout(function(){
	      //做法就是那开始记录的复制回去
		  if(element.scrollTop != scrolTop){
		     element.scrollTop == scrolTop;
		  }
	   },10);
	}
}

 日后会慢慢贴出其他的代码,只是学习之用。谢谢查看。

 

附上源码和例子,希望对你的学习有帮助,谢谢

 

1
0
分享到:
评论

相关推荐

    前端开源库-xss-filters

    总结起来,"前端开源库-xss-filters"是一个专注于防止XSS攻击的工具,它通过提供强大的过滤功能,帮助开发者保护用户免受恶意脚本的侵害。开发者应当重视XSS防护,合理使用这样的开源库,提升应用程序的安全性。同时...

    前端开源库-ipld-raw

    在IT行业中,前端开发是构建Web应用程序的关键部分,而开源库则是开发者们共享和复用代码的重要工具。本文将深入探讨“前端开源库-ipld-raw”,一个专门处理ipld raw格式的JavaScript实现。 首先,我们需要理解ipld...

    BAT批处理脚本-文件相关操作-92个.zip

    BAT批处理脚本-WinXP相关批处理-12个 BAT批处理脚本-加密解密-22个 BAT批处理脚本-实用的批处理文件-70个 BAT批处理脚本-提示窗口进度条-17个 BAT批处理脚本-数值计算-23个 ...BAT批处理脚本-网络相关操作-44个

    前端开源库-fs-recurse

    "fs-recurse" 是一个专为前端设计的开源库,它主要用于异步地遍历文件系统目录,尤其适用于处理文件和文件夹的递归操作。在深入探讨这个库之前,我们需要先理解一些基本概念。 首先,`fs` 模块是 Node.js 的核心...

    前端开源库-node-red-contrib-securedhttp

    《前端开源库——Node-Red-Contrib-SecuredHTTP详解》 在当今互联网技术日新月异的时代,前端开发人员面临着构建高效、安全且可扩展的Web应用的挑战。在这个背景下,开源库扮演了至关重要的角色,它们为开发者提供...

    前端开源库-alinex-ssh

    "alinex-ssh"这个开源库就是基于Node.js实现的SSH客户端库,它允许前端开发者在JavaScript环境中方便地操作远程服务器。Node.js是JavaScript的服务器端运行环境,其非阻塞I/O和事件驱动的特性使其在处理大量并发连接...

    前端开源库-hmacsha1

    **前端开源库-hmacsha1** 是一个专为JavaScript环境设计的实现HMAC-SHA1算法的开源库。HMAC(Hash Message Authentication Code)是一种基于密钥的哈希消息认证码,它结合了散列函数(如SHA1)和密钥来确保数据的...

    前端开源库-run-script-os

    "run-script-os" 是这样一个开源库,专门用于处理跨操作系统运行NPM脚本的问题。这个工具使得开发者能够在不同的操作系统(如Windows、macOS和Linux)上,使用统一的命令来执行操作系统的特定任务,而无需关心底层...

    BAT批处理脚本-文本操作-52个.zip

    BAT批处理脚本-WinXP相关批处理-12个 BAT批处理脚本-加密解密-22个 BAT批处理脚本-实用的批处理文件-70个 BAT批处理脚本-提示窗口进度条-17个 BAT批处理脚本-数值计算-23个 ...BAT批处理脚本-网络相关操作-44个

    BAT批处理脚本-网络相关操作-44个.zip

    BAT批处理脚本-WinXP相关批处理-12个 BAT批处理脚本-加密解密-22个 BAT批处理脚本-实用的批处理文件-70个 BAT批处理脚本-提示窗口进度条-17个 BAT批处理脚本-数值计算-23个 ...BAT批处理脚本-网络相关操作-44个

    前端开源库-language-map

    **前端开源库-language-map** 是一个专为前端开发者设计的工具,它以 **Yaml** 语言编写的地图数据,并转换成 **JSON** 格式供用户使用。这个项目的目标是帮助开发者更好地理解和掌握前端开发中所涉及的各种编程语言...

    前端开源库-key-value-store

    "前端开源库-key-value-store" 提供了一个高效、轻量级的解决方案,用于在浏览器环境中实现键值对(key-value pairs)的存储。这类存储系统对于管理应用程序的状态、缓存数据或持久化用户设置非常有用。本文将深入...

    前端开源库-janeway

    Janeway的独特之处在于它的鼠标驱动特性,这意味着用户可以通过简单的鼠标操作来执行命令,使得交互过程更加直观和高效。 在前端开发中,开发者经常需要即时测试JavaScript代码片段或尝试新的API功能。传统的命令行...

    前端开源库-cross-spawn-with-kill

    在前端开发领域,开源库是开发者们不可或缺的资源,它们为我们的工作提供了便利,提高了效率。"cross-spawn-with-kill"就是一个这样的工具,专为了解决跨平台进程管理的问题。这个库是针对Node.js环境设计的,它扩展...

    前端开源库-mt-uz

    【前端开源库-mt-uz】是一个专门为"Mt"调用"Uz"设计的前端开源库。在当前数字化时代,前端开发已经成为构建交互式、动态网页应用的关键部分,而开源库则是开发者们共享和利用代码资源的重要平台。 Mt-uz致力于提供一...

    前端开源库-smooth-fe

    "前端开源库-smooth-fe" 是一个专注于前端性能优化的开源项目,它的主要目标是提供一套解决方案,使得CSS和JavaScript的加载与执行更加平滑、高效。在现代Web开发中,用户体验是至关重要的,而页面的加载速度和交互...

    前端开源库-jms-deploy

    **前端开源库-jms-deploy** 前端开源库`jms-deploy`是一个专门针对Java消息服务(Java Message Service,简称JMS)的部署工具。它为前端开发者提供了一种便捷的方式来将前端应用部署到支持JMS协议的服务器上,使得...

    前端开源库-koa-helmet

    **标题与描述解析** 标题"前端开源库-koa-helmet"指出我们关注的是一个用于前端开发的开源库,它的名字叫"koa-helmet"。Koa是Node.js的一个Web应用...了解并正确使用Koa-helmet,是保障前端应用安全的关键步骤之一。

    前端开源库-browser-test-runner

    【前端开源库-browser-test-runner】是一个专为前端开发者设计的测试工具,它的主要目标是提供一个高效的、跨浏览器的测试运行环境,使开发者能够在多种不同的浏览器中方便地运行和调试他们的代码测试。这个库允许...

    前端开源库-assets-bower-ci-legacy

    "assets-bower-ci-legacy"可能包含了一套解决方案,用于确保这些前端库能在老版本的浏览器中正常工作,或者包含了处理旧版浏览器兼容问题的工具和策略。 在压缩包`assets-bower-ci-legacy-master`中,我们可能找到...

Global site tag (gtag.js) - Google Analytics