文章参考地址:http://blog.csdn.net/nhconch/article/details/4223076

需求背景:

前几天,因为客户有一个需求说,需要对一个评论(一个textarea文本框)的长度进行限制,简单的理解就是 这个文本框只能输入100个字符,然后就不能在输入了!

实现方案一:用maxlength属性

 <textarea maxlength="10"></textarea>

这个方式很简单的哦,但是 在我这边测试的时候,并不能完全兼容主流浏览器

兼容性效果如下:

IE8 Firefox 17 Chrome 23
不兼容 兼容 兼容

实现方案二:用javascript实现

<textarea name="txt1" cols="45" rows="2" onKeyDown='if (this.value.length>=20){event.returnValue=false}'></textarea>

这里就用到了一个onKeyDown。但是效果也不太理想。

兼容性效果如下:

IE8 Firefox 17 Chrome 23
兼容 不兼容 兼容

实现方案三:综合上面的方法

因为上面无法兼容IE 和firefox,没办法,只能贱一点了!~所以,我就把上面的方法给综合起来~~

代码如下:

 <textarea name="txt1" cols="45" maxlength="20" rows="2"  onKeyDown='if (this.value.length>=20){event.returnValue=false}'>b</textarea>

注意哦,我只是把maxlength加上了!

兼容性效果如下:

IE8 Firefox 17 Chrome 23
兼容 兼容 兼容

原因很简单,maxlength是对firefox和chrome兼容,而那js代码是对IE 兼容。所以就ok啦!!我把

嘻嘻。。那天因为要提交这个ticket 所以急着交咯,反正客户那边通过啦。。哇哇哇。。

实现方案四:JavaScript的substring

 <textarea name="blogdesc" cols="50" rows="5" onkeyup="limitLength(this,20)">x </textarea>  

js 代码:

function limitLength(obj, length) {
var desc = obj.value;
obj.value = substr(obj.value, length);
}
function substr(str, length) {
var l = 0, i = 0;
while (l < length && i < str.length) {
l += 1;
if (str.substring(i, i + 1).match(/[\u4e00-\u9fa5]/)) l += 2; //一个中文是相当于3个英文
i += 1;
}
return str.substring(0, i);
}

兼容性效果如下:

IE8 Firefox 17 Chrome 23
兼容 兼容 兼容

但是,其实这个虽然上面三个都兼容,但是有一个很不友好的问题是,当你达到字符限制的时候,它还会打出来,直到你松开按键的时候就好了。不过,这个时候 会有闪一下把后面多余的字符给删除了!~。不太友好哦!~亲。

实现方案五:JavaScript

 <textarea maxlength="10" onpropertychange="onmyinput(this)" oninput="return onmyinput(this)"
onpaste="return onmypaste(this);" onkeypress="return onmykeypress(this);"></textarea>

js代码是:

function onmyinput(o) {
if (o.value.length >= o.getAttribute("maxlength")) {
if (o.value.length > o.getAttribute("maxlength"))
o.value = o.value.substring(0, o.getAttribute("maxlength"));
return false;
}
return true;
}
function mygetclipdata() {
if (!document.all) {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
trans.addDataFlavor('text/unicode');
var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
clip.getData(trans, clip.kGlobalClipboard);
var str = new Object();
var strLength = new Object();
trans.getTransferData("text/unicode", str, strLength);
if (str)
str = str.value.QueryInterface(Components.interfaces.nsISupportsString);
var pastetext;
if (str)
pastetext = str.data.substring(0, strLength.value / 2);
return pastetext;
}
else {
return window.clipboardData.getData("Text");
}
}
function mysetclipdata(o) {
if (!document.all) {
netscape.security.PrivilegeManager.enablePrivilege('UniversalXPConnect');
var clip = Components.classes['@mozilla.org/widget/clipboard;1'].createInstance(Components.interfaces.nsIClipboard);
var trans = Components.classes['@mozilla.org/widget/transferable;1'].createInstance(Components.interfaces.nsITransferable);
trans.addDataFlavor("text/unicode");
var str = Components.classes["@mozilla.org/supports-string;1"].createInstance(Components.interfaces.nsISupportsString);
str.data = o;
trans.setTransferData("text/unicode", str, o.length * 2);
var clipid = Components.interfaces.nsIClipboard;
clip.setData(trans, null, clipid.kGlobalClipboard);
}
else {
window.clipboardData.setData("Text", o);
}
}
function onmypaste(o) {
var nMaxLen = o.getAttribute ? parseInt(o.getAttribute("maxlength")) : "";
if (!document.all) {
alert("不可能执行的代码");
}
else { if (document.selection.createRange().text.length > 0) {
var ovalueandclipboarddata = o.value + window.clipboardData.getData("Text");
if (o.getAttribute && ovalueandclipboarddata.length - document.selection.createRange().text.length > nMaxLen) {
if (window.clipboardData.getData("Text").substring(0, document.selection.createRange().text.length + nMaxLen - o.value.length) != "")
window.clipboardData.setData("Text", window.clipboardData.getData("Text").substring(0, document.selection.createRange().text.length + nMaxLen - o.value.length));
else
return false;
}
}
else {
var ovalueandclipboarddata = o.value + window.clipboardData.getData("Text");
if (o.getAttribute && ovalueandclipboarddata.length > nMaxLen) {
if (ovalueandclipboarddata.substring(0, nMaxLen - o.value.length) != "")
window.clipboardData.setData("Text", ovalueandclipboarddata.substring(0, nMaxLen - o.value.length));
else
return false;
}
}
return true;
}
}
function onmykeypress(o) {
if (!document.all) {
var nMaxLen = o.getAttribute ? parseInt(o.getAttribute("maxlength")) : ""; if (onmykeypress.caller.arguments[0].ctrlKey == true) {
if (onmykeypress.caller.arguments[0].which == 118) { if (o.selectionStart < o.selectionEnd) {
var ovalueandclipboarddata = o.value + mygetclipdata();
if (o.getAttribute && (ovalueandclipboarddata.length - o.selectionEnd + o.selectionStart > nMaxLen)) {
if (mygetclipdata().substring(0, o.selectionEnd - o.selectionStart + nMaxLen - o.value.length) != "")
mysetclipdata(mygetclipdata().substring(0, o.selectionEnd - o.selectionStart + nMaxLen - o.value.length));
else
return false;
}
}
else {
var ovalueandclipboarddata = o.value + mygetclipdata();
if (o.getAttribute && ovalueandclipboarddata.length > nMaxLen) {
if (ovalueandclipboarddata.substring(0, nMaxLen - o.value.length) != "")
mysetclipdata(ovalueandclipboarddata.substring(0, nMaxLen - o.value.length));
else
return false;
}
}
return true; }
} if (onmykeypress.caller.arguments[0].which == 0 || onmykeypress.caller.arguments[0].which == 8)
return true;
if (o.value.length >= o.getAttribute("maxlength")) {
if (o.selectionStart < o.selectionEnd)
return true;
if (o.value.length > o.getAttribute("maxlength"))
o.value = o.value.substring(0, o.getAttribute("maxlength"));
return false;
}
else
return true; }
else {
if (document.selection.createRange().text.length > 0)
return true;
if (o.value.length >= o.getAttribute("maxlength"))
return false;
else
return true;
}
}
 
IE8 Firefox 17 Chrome 23
兼容 兼容 兼容
 
 
 
 
 

限制textarea 文本框的长度(收集了几个办法)的更多相关文章

  1. 如何限制textarea文本框的输入字数

    代码实例如下: <!doctype html><html><head><meta charset="UTF-8"><title ...

  2. jQuery实现限制input框 textarea文本框输入字符数量的方法

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  3. Jquery实现 TextArea 文本框根据输入内容自动适应高度

    原文 Jquery实现 TextArea 文本框根据输入内容自动适应高度 在玩微博的时候我们可能会注意到一个细节就是不管是新浪微博还是腾讯微博在转发和评论的时候给你的默认文本框的高度都不会很高,这可能 ...

  4. 【kindeditor】KindEditor获取多个textarea文本框的值并判断非空

    kindeditor官网:http://kindeditor.net/demo.php 如何获取多个KindEditor中textarea文本框的值,方式很多种(带有HTML标签). var intr ...

  5. js限制textarea文本框的文字个数

    现在发微博,那个文本框一般只能输入200字好像,再多就会自动删除,要么是提示字数受限,用Js就可实现本功能.今天带来的这个Js限制表单文本 框文字数量的例子,相信有此方面需要的是个不错的参考.为了便于 ...

  6. html5 textarea 文本框根据输入内容自适应高度

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  7. JS案例 - 可自动伸缩高度的textarea文本框

    文本框的默认现象: textarea如果设置cols和rows来规定textarea的尺寸,那么textarea的默认宽高是这俩属性设置的值,可以通过鼠标拖拽缩放文本框的尺寸. textarea如果设 ...

  8. JS实时检测文本框内容长度

    通过js代码实时监测,文本框内容的变化以及长度,下图是一个实际使用场景. HTML部分: <input id="Text1" type="text" on ...

  9. contenteditable模仿textarea文本框

    contenteditable 属性是 HTML5 中的新属性. 例子:<p contenteditable="true" style=" border:solid ...

随机推荐

  1. jiagu-工具使用

    比较好的一套处理工具吧,感谢作者,原文地址:https://github.com/ownthink/Jiagu 练习一下使用 """ Funciton: jiagu测试 ...

  2. spring JDBC的应用

    原文地址:https://www.iteye.com/blog/chen106106-1574911 1:首先在类路径下面配置访问数据的一些基本信息,包括连接数据库的地址,用户,密码jdbc.prop ...

  3. Java选择结构和循环结构

    1.选择结构 ①.ifif(){ } if(){}else{} if(){}else if(){}else if(){}else{} ②.switch switch (表达式) { case 常量 1 ...

  4. 第四节:EF Core的并发处理

    1.说明 和EF版本的并发处理方案一致,需要知道乐观并发和悲观并发的区别,EF Core只支持乐观并发:监控并发的两种方案:监测单个字段和监测整条数据,DataAnnotations 和 Fluent ...

  5. python selenium IE Firxfor pyinstaller

    以前在python环境下selenium 主要用的是chromdriver,这次发现老是报错(Timeout), 实际又是正确的, 可能是和chrome版本不正确,再加上我程序蹦来就在windows环 ...

  6. 『金字塔 区间dp』

    金字塔 Description 虽然探索金字塔是极其老套的剧情,但是这一队 探险家还是到了某金字塔脚下.经过多年的研究,科 学家对这座金字塔的内部结构已经有所了解.首先, 金字塔由若干房间组成,房间之 ...

  7. XAML加载的四种方式

    XAML加载与编译可以分为四种: 仅使用代码进行WPF程序的生成 使用代码和未编译的标记 使用代码和编译过的BAML 1.只是用代码进行窗体的生成:优点是可以随意定制应用程序,缺点是没有可视化编辑窗口 ...

  8. 汉诺(hanio)塔问题

    规则:大盘子不能压在小盘子上.要求:将A柱子上所有盘(每个盘大小不同)放到C柱子上,使用B柱子作辅助. 比如柱子A上有n个盘,执行以下步骤: 1. 把n-1个盘从源柱移动到临时柱上: 2. 把源柱上剩 ...

  9. 关于Svn服务总是链接异常

    之前一直在使用,本机电脑也没有修改网络环境却一直无法链接svn. 每次剪切代码都提示: ping服务ip可以ping通,域名却总是不通. 百度结果各种clear缓存,还不行 结果使用 在本地C:\Wi ...

  10. element-UI级联选择器(Cascader)获取label值 ,this.$refs['新组件名'].currentLabels 在2.7版本给移除了,新的解决方法。

    原文参考:https://blog.csdn.net/lijiabinbbg/article/details/97396812 遇到的新的问题是如果设置了ref,那么v-model绑定的值不会动态更新 ...