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

dndgkr 2009-08-25 09:12:17
中文应该是两个字节,而英文字母占一个字节。
如何准确在客户端判断到底输入了多少个字节.
例如:TXTAREA 汉字要输入300 英文600
...全文
1556 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,“中国中国中国”仍然还在。
超出了字节我想把超出的字节去掉只显示“中国中国中”然后光标到“中”后面一闪一闪???
内容概要:本文提出了一种基于Matlab代码实现的含多微电网租赁共享储能的配电网博弈优化调度方法,旨在解决多个微电网通过租赁共享储能系统参与配电网协同优化运行的问题。研究采用博弈论对多微电网主体进行建模,综合考虑各主体之间的竞争与合作关系,构建了兼顾经济性、稳定性和公平性的优化调度模型。该方法深入探讨了多主体利益均衡机制、共享储能租赁机制设计、资源优化配置及运行策略制定等关键环节,并通过Matlab实现了调度模型的求解算法,能够有效提升复杂电力环境下多微电网系统的整体运行效率与经济效益。; 适合人群:具备电力系统分析、优化调度理论或博弈论基础的科研人员、电气工程及相关专业的研究生,以及从事能源互联网、微电网规划与运行的工程技术与管理人员。; 使用场景及目标:①用于多微电网与共享储能系统的协同优化调度研究与仿真验证;②支撑高比例分布式能源接入背景下主动配电网的能量管理、共享经济机制设计及博弈决策模型构建;③为相关领域学术论文撰写、科研项目申报与实际工程应用提供可复现的Matlab代码支持与技术参考。; 阅读建议:建议结合Matlab代码与技术文档同步学习,重点关注博弈模型的构建逻辑、目标函数的设计思路及约束条件的数学表达,推荐通过调整参数设置开展多情景仿真实验,深入理解共享储能租赁机制对各微电网运行成本与系统整体性能的影响规律。
内容概要:本文研究了一种具有单个开关电容支路的高增益准Z源直流-直流变换器,通过Simulink仿真实现对其性能进行全面分析与验证。该变换器融合了准Z源网络的独特优势,能够在降低半导体器件电压应力的同时实现显著的电压增益,有效克服传统升压变换器在高增益需求下面临的器件耐压高、效率低等问题。文章系统阐述了其电路拓扑结构、工作原理、关键参数设计方法及PWM控制策略,并通过详尽的仿真结果验证了其在稳态运行下的高升压能力、低输入电流纹波特性以及在动态负载变化下的良好响应能力和稳定性。此外,重点分析了开关电容支路在电压泵升过程中的作用机制,揭示了其实现高增益的核心原理。; 适合人群:电力电子、电气工程及其自动化等相关专业的高校研究生、科研人员,以及从事新能源发电系统、电动汽车、航空航天电源等高升压比应用领域产品研发的工程技术人员。; 使用场景及目标:①应用于光伏并网、燃料电池供电、电动汽车驱动等需要高升压比且对系统效率、可靠性和功率密度要求较高的直流变换场合;②为新型高增益DC-DC变换器的拓扑结构创新与性能优化提供理论依据和技术参考;③作为高等院校电力电子技术、现代电源技术等课程的教学案例或科研实验平台,用于深入理解准Z源变换器和开关电容技术的工作机理。; 阅读建议:建议读者结合提供的Simulink仿真模型,深入剖析变换器在不同工作模态下的能量传递过程,重点关注开关电容的充放电回路及电压叠加机制;可通过调整占空比、开关频率、电容电感值等参数进行仿真对比,探究其对电压增益、纹波大小及动态性能的影响,从而全面掌握高增益变换器的设计规律与优化方法。

87,991

社区成员

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

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