如何用JS判断用户输入了多少个字节?JS将中文和字母都看成一个长度

dndgkr 2009-08-25 09:12:17
中文应该是两个字节,而英文字母占一个字节。
如何准确在客户端判断到底输入了多少个字节.
例如:TXTAREA 汉字要输入300 英文600
...全文
1538 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
BeenZ 2009-08-25
  • 打赏
  • 举报
回复
LZ可以把(len>600) 该成if(len>10),既:汉字5个,英文10个的限制 ,然后试
BeenZ 2009-08-25
  • 打赏
  • 举报
回复
....就是这样用啊

<HTML><HEAD>
<TITLE>test</TITLE>
<meta http-equiv=content-type content="text/html; charset=UTF-8">
<script language=javascript>

function test(){
var testInput=document.getElementById("test").value;
var len=testInput.len()
if(len>600)
alert("超过限制");
}

String.prototype.len = function() {
return this.replace(/[^\x00-\xff]/g, 'xx').length;
};
</script>
</head>
<body>
<div><input type=text id="test" /><input type=button value="测试" onclick=test()></div>
</body>
</html>


自己去试 ,汉字超过300会提示,英文超过600会提示,混合超过600个字节一样会提示
dndgkr 2009-08-25
  • 打赏
  • 举报
回复
那么直接判断的话不行 。 。
上面的是只能取出输入汉英的长度。
直接判断600的话我要求的题不符合。
我说的是
String.prototype.len = function() {
return this.replace(/[^\x00-\xff]/g, 'xx').length;
};
这个代码准确取出输入汉英的长度。
我想实现的是:
txt长度设为600字节。
在TXT里光输入汉字的话 判断汉字 > 300 超过限制。
在TXT里光输入英文的话 判断英文 > 600 超过限制。

在TXT里汉英混合输入的话 我得怎么判断???
BeenZ 2009-08-25
  • 打赏
  • 举报
回复
function test(){
var testInput=document.getElementById("test").value;
var len=fucCheckLength(testInput);
if(len>600) alert("out of range");
}

楼上方法同理
function test(){
var testInput=document.getElementById("test").value;
if(testInput.len>600) alert("out of range");
}
dndgkr 2009-08-25
  • 打赏
  • 举报
回复
String.prototype.len = function() {
return this.replace(/[^\x00-\xff]/g, 'xx').length;
};
这个代码挺好的, , 准确判断输入的汉字或英文是几个字节。
我想把txt长度设为600字节。
在TXT里光输入汉字的话 判断汉字 > 300 超过限制。
在TXT里光输入英文的话 判断英文 > 600 超过限制。

在TXT里汉英混合输入的话 我得怎么判断???
BeenZ 2009-08-25
  • 打赏
  • 举报
回复
来个完整的吧
HTML code

<HTML><HEAD>
<TITLE>test</TITLE>
<meta http-equiv=content-type content="text/html; charset=UTF-8">
<script language=javascript>
function fucCheckLength(strTemp)
{
var i,sum;
sum=0;
for(i=0;i<strTemp.length;i++){
if ((strTemp.charCodeAt(i)>=0) && (strTemp.charCodeAt(i)<=255)){
sum=sum+1;
}else{
sum=sum+2;
}
}
return sum;
}
function test(){
var testInput=document.getElementById("test").value;
var len=fucCheckLength(testInput);
alert("长度是"+len);
}


</script>
</head>
<body>
<div><input type=text id="test" /><input type=button value="测试" onclick=test()></div>
</body>
</html>
spring2007 2009-08-25
  • 打赏
  • 举报
回复
帮顶
BeenZ 2009-08-25
  • 打赏
  • 举报
回复
<script language=javascript>

function fucCheckLength(strTemp)
{
var i,sum;
sum=0;
for(i=0;i<strTemp.length;i++){
if ((strTemp.charCodeAt(i)>=0) && (strTemp.charCodeAt(i)<=255)){
sum=sum+1;
}else{
sum=sum+2;
}
}
return sum;
}
function test(val){
var len=fucCheckLength(val);
alert(len)
}


</script>
wcwtitxu 2009-08-25
  • 打赏
  • 举报
回复

String.prototype.len = function() {
return this.replace(/[^\x00-\xff]/g, 'xx').length;
};

alert("文字abc".len());
mykelly6 2009-08-25
  • 打赏
  • 举报
回复
算charcode是比较常见的做法,不过这个没什么用,一般都中英文统一处理了,没必要弄的那么细。
之前设计非要让我这么做,最后客户说删了吧。。
tidelgl 2009-08-25
  • 打赏
  • 举报
回复
把字符都拿来判断,统计字母个数和汉字个数再确定按新长度计算方式计算长度嘛
可以用正则表达式,速度快
ws_hgo 2009-08-25
  • 打赏
  • 举报
回复
http://blog.csdn.net/ws_hgo/archive/2009/07/31/4398515.aspx
ws_hgo 2009-08-25
  • 打赏
  • 举报
回复
<!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>判断输入的字数</title>
<mce:script type="text/javascript"><!--
function Checkval()
{
var s=document.getElementById("Text1").value;
var n=0;
for(var i=0;i<s.length;i++)
{
//charCodeAt()可以返回指定位置的unicode编码,这个返回值是0-65535之间的整数
if(s.charCodeAt(i)<128)
{
n++;
}
else
{
n+=2;
}
}
alert(n);
}

// --></mce:script>
</head>
<body>
<input id="Text1" type="text" onblur="Checkval()" />
</body>
</html>

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/ws_hgo/archive/2009/07/31/4398515.aspx
dndgkr 2009-08-25
  • 打赏
  • 举报
回复
我设置了10字节
String.prototype.len = function() {
return this.replace(/[^\x00-\xff]/g, 'xx').length;
}
用上面的代码来判断输入的是多少字节。
然后判断并提示错误信息。
我想实现的是我在TXTBOX里输入了“中国中国中国”
这样的话超出了10字节,判断 > 10 提示错误信息。
然后看一看TXTBOX,“中国中国中国”仍然还在。
超出了字节我想把超出的字节去掉只显示“中国中国中”然后光标到“中”后面一闪一闪???
代码下载链接: https://pan.quark.cn/s/23ff226fe24b ### iTest自动化测试工具知识点详解#### 一、iTest自动化测试工具简介iTest是由业界领先测试设备制造商Spirent所研发的一款自动化测试工具。该工具为用户呈现了一个集成化的自动化测试解决方案,借助这一工具,用户能够完成软件及网络测试的编写与自动化执行。iTest不仅适用于专业的测试工程师,对于非测试人员来说,同样是一个功能强大的工具,能够协助他们对网络中的设备和应用进行访问和自动化操作。#### 二、iTest Lite快速入门指南iTest Lite是一款免费提供给用户的版本,其目的是为用户呈现一个简明的iTest产品概览。用户可以从官方网站(www.fanfaresoftware.com)获取并安装iTest Lite。此工具不仅能够支持用户进行软件和网络测试,还能用于对网络上的设备或应用程序进行管理和自动化。#### 三、iTest的工作流程- **主页内容**:在iTest被启动之后,主页内容将展示在右侧,而活动列表则位于左侧。主页上不仅包含欢迎消息,还会提供iTest工作流程的高级图示以及链接到Fanfare社区的入口,用户可以通过论坛帖子、教程视频等资源进一步了解iTest。 - **活动列表**:这是使用iTest功能的推荐起点。活动列表包含以下几个部分: - **连接设备**:一种便捷的方法来验证iTest是否能够连接到测试设备。 - **构建拓扑结构**:在这一步骤中,可以迅速定义一组想要进行测试的设备或应用程序。 - **开发测试用例**:创建一个自动化的测试用例,用于针对任何特定的拓扑结构进行测试。 - **查看测试报告**:访问个人...
代码下载链接: https://pan.quark.cn/s/89ea75840350 STM32微控制器的实时时钟(RTC)作为一个独立的计时单元,能够在系统重启或从休眠状态激活后持续保持时间设置不变。本文将详细探究STM32 RTC的运行机制,涵盖时钟结构图解析以及时间显示的原理。需要明确的是,STM32的RTC模块坐落于备份领域(Backup domain),它借助32.768kHz的辅助晶体振荡器作为时钟供给。在进行RTC编程实践时,务必小心谨慎地处理与RTC相关的寄存器配置。随后,我们将借助RTC时钟结构图展开深入剖析。时钟结构图主要由两大块构成:APB1接口区块与RTC主控单元。APB1接口区块负责对与RTC关联的寄存器进行数据交互,而RTC主控单元内含两个子模块:RTC分频调节模块以及一个32位可变步长计数器。在RTC主控单元内部,有几个关键寄存器是必须掌握的:1. RTC_DIV(RTC分频调节余数寄存器):此寄存器旨在获取超越秒级的更高精度时间(如0.1秒、0.01秒)。该寄存器在数值减至极值后会由硬件自动重置。其数值由RTC_PRL(RTC分频调节装载寄存器)提供,其时钟频率源自RTCCLK。2. RTC_PRL(RTC分频调节装载寄存器):它为RTC_DIV提供重置数值,同时用于设定时钟频率的缩放比例。例如,若晶体振荡器频率为32.768KHz,将RTC_PRL设定为32767,即可得到每秒的计数速率。3. RTC_CNT(RTC计数器寄存器):该寄存器记录秒数,并可用于触发计数器溢出中断。4. RTC_ALR(RTC闹钟寄存器):用于设定闹钟时刻,一旦计数器的数值与闹钟寄存器匹配,并且中断功能已启用,便会引发一个闹钟中断事件。在物理实现层...

87,994

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧