空包网这么多,购买空包网站哪个好

JS判断字符串字节数并截取长度的方法
作者:程序诗人
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了JS判断字符串字节数并截取长度的方法,涉及JavaScript针对页面元素与字符串的动态操作技巧,需要的朋友可以参考下
本文实例讲述了JS判断字符串字节数并截取长度的方法。分享给大家供大家参考,具体如下:
这是在项目制作中,积累到的一个东西,感觉效果还可以,现在贴上效果:
那么,在页面上,我们需要检测两个东西,一个就是字节数,一个就是字符数。
由于数据库中,要求title的长度字节数为200,那么具体的js代码如下:
/*************************************************************************
* CodeBy:SCY CodeDate:日 12:01:16
* DESC:主要是用来判断当前输入的字节数,以便做到限制输入标题的长度功能
**************************************************************************/
var matchW
function notifyTextLength() {
var inputNum = document.getElementById("txtTitle").value.replace(/[^\x00-\xff]/g, "**"). //得到输入的字节数
if (inputNum &= 200) {
matchWords = document.getElementById("txtTitle").value.
document.getElementById("inputedWord").innerHTML = inputNum + "字节," + matchWords + "字符";
document.getElementById("inputtingWord").innerHTML = (200 - inputNum) + "字母,"+(Math.round(((200-inputNum)/2)-0.5))+"汉字";
if (inputNum & 200) {
document.getElementById("txtTitle").value = document.getElementById("txtTitle").value.substring(0, matchWords); //如果超过200字节,就截取到200字节
其中,matchWords代表的是当字节数小于200的情况下,匹配的字符的个数;inputNum则是输入的字节数。
当标题输入的字节数大于200的时候,就按照字符个数进行截取。
html代码如下:
&input id="txtTitle" type="text" class="inputText" runat="server" onpropertychange="notifyTextLength();" /&
当前已经输入&span id="inputedWord" style="color:red"&&/span&
还可以输入&span id="inputtingWord" style="color:R"&&/span&
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具JS判断字符串长度的5个方法(区分中文和英文)
字体:[ ] 类型:转载 时间:
这篇文章主要介绍了JS判断字符串长度的5个方法,并且区分中文和英文,需要的朋友可以参考下
目的:计算字符串长度(英文占1个字符,中文汉字占2个字符)
方法一: 代码如下:String.prototype.gblen = function() {& & var len = 0;& & for (var i=0; i&this. i++) {& &&& if (this.charCodeAt(i)&127 || this.charCodeAt(i)==94) {& &&&&&& len += 2;& &&&& } else {& &&&&&& len ++;& &&&& }& && }& && }方法二: 代码如下:function strlen(str){&&& var len = 0;&&& for (var i=0; i&str. i++) { &&&& var c = str.charCodeAt(i); &&& //单字节加1 &&&& if ((c &= 0x0001 && c &= 0x007e) || (0xff60&=c && c&=0xff9f)) { &&&&&& len++; &&&& } &&&& else { &&&&& len+=2; &&&& } &&& } &&&}方法三: 代码如下:var jmz = {};jmz.GetLength = function(str) {& ///&summary&获得字符串实际长度,中文2,英文1&/summary&& ///&param name="str"&要获得长度的字符串&/param&& var realLength = 0, len = str.length, charCode = -1;& for (var i = 0; i & i++) {&&& charCode = str.charCodeAt(i);&&& if (charCode &= 0 && charCode &= 128) realLength += 1;&&& else realLength += 2;& }& return realL};方法四: 代码如下:var l = str. var blen = 0; for(i=0; i&l; i++) { if ((str.charCodeAt(i) & 0xff00) != 0) { blen ++; } blen ++; }方法五:把双字节的替换成两个单字节的然后再获得长度
代码如下:getBLen = function(str) {& if (str == null) return 0;& if (typeof str != "string"){&&& str += "";& }& return str.replace(/[^\x00-\xff]/g,"01").}
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
&&&&&& p lic static void main(String[] args) throws Exception{
&&&&&&&&&&&&& String str = "aabcdef';
&&&&&&&&&&&&& String str = "ABC";
&&&&&&&&&&&&& int num = trimGBK(str.getBytes("GBK"),5);
&&&&&&&&&&&&& System.out.println(str.s string(0,num) );
&&&p lic static int& trimGBK(byte[] b,int n){
&&&&&&&&&&&&& int num = 0;
&&&&&&&&&&&&& boolean bChineseFirstHalf =
&&&&&&&&&&&&& for(int i=0;i&n;i++)
&&&&&&&&&&&&& {
&&&&&&&&&&&&&&&&&&&& if(b[i]&0 && !bChineseFirstHalf){
&&&&&&&&&&&&&&&&&&&&&&&&&&& bChineseFirstHalf = tr;
&&&&&&&&&&&&&&&&&&&& }else{
&&&&&&&&&&&&&&&&&&&&&&&&&&& num++;
&&&&&&&&&&&&&&&&&&&&&&&&&&& bChineseFirstHalf =&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&& }
&&&&&&&&&&&&& }
&&&&&&&&&&&&&
}自己写的珍藏代码:&/**&&&&&&*&用getBytes(encoding):返回字符串的一个byte数组&&&&&&*&当b[0]为&63时,应该是转码错误&&&&&&*&A、不乱码的汉字字符串:&&&&&&*&1、encoding用GB2312时,每byte是负数;&&&&&&*&2、encoding用ISO8859_1时,b[i]全是63。&&&&&&*&B、乱码的汉字字符串:&&&&&&*&1、encoding用ISO8859_1时,每byte也是负数;&&&&&&*&2、encoding用GB2312时,b[i]大部分是63。&&&&&&*&C、英文字符串&&&&&&*&1、encoding用ISO8859_1和GB2312时,每byte都大于0;&&&&&&*&&p/&&&&&&&*&总结:给定一个字符串,用getBytes("
iso_nbsp>&&&&&*&1、如果b[i]有63,不用转码;&A-2&&&&&&*&2、如果b[i]全大于0,那么为英文字符串,不用转码;&B-1&&&&&&*&3、如果b[i]有小于0的,那么已经乱码,要转码。&C-1&&&&&&*/& String string = "啊"; &&
& & & &byte by[] = string.getBytes(); &
& & & &for(int i=0;i&by.i++)
System.out.println(by[i]);
& & & &try {
by = string.getBytes("utf8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
&for(int i=0;i&by.i++)
&System.out.println(by[i]);
by = string.getBytes("gb2312");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
& & & &for(int i=0;i&by.i++)
System.out.println(by[i]);
& & & &try {
by = string.getBytes("iso-8859-1");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
& & & &for(int i=0;i&by.i++)
System.out.println(by[i]);输出结果:-80-95*-27-107-118*-80-95*63转了一篇挺好的文章:关于Java编码问题Java的编码问题挺烦的,以前总弄不清除,现在理了一下算是清晰一点。做个总结吧~编码问题的由来这个问题网上资料很多的,这里不多说了,推荐几篇吧。,,。说的还是比较清楚了。下面主要用程序说说。String是什么?以前一直不清楚Java编码转来转去转的是啥。原来是因为不知道String是啥。在Java里,一个String就是一串Unicode编码的字符串。也就是说,Java在整个处理过程中,字符都是以Unicode编码的。具体使用的是UTF-16也就是双字节的Unicode编码。这就解释了Java中为啥有个16bit的char类型。String就是由一个个char组成的。一个char中存的就是一个对应字符的Unicode编码。所以,Unicode在Java中成为一种“中间码”,因为他覆盖了基本上所有的字符。而其他编码的转换都可以通过他来完成。PS:话说回来,用双字节的话还是无法覆盖整个字符集的(因为有UTF-32),所以以前曾怀疑过char是否真是用来放Unicode字符的,只有16的话以后扩展怎么办?现在确定了,扩展问题目前不用考虑。。。转什么?怎么转?这里再说一个东西——byte。为啥说它?因为所有的转来转去都是在转它。为啥转它?因为他是字符编码的最小单位。一个byte 是8bit,所有编码方式都是由整数个byte组成的。所以,同一个String的不同编码方式可以理解为同一个字符的不同byte数组表示而已。所以,自然而然我们就可以看到这样的代码了:String S = “测试”s.getBytes(“utf8″);s.getBytes(“GB2312″);s.getBytes(“GBK”);通过这种方式就可以获得任何编码的byte数组。所以,在知道了一个byte[]数组,和它的编码方式的情况下,我们就能获得对应的String,所以有了下面的代码:byte[] b = *****;String s = new String(b, “utf8″);s = new String(b, “gb2312″);通过上面可以看出,从String可以获得任何编码的byte数组,但是从byte数组到String就要小心了,必须知道对应的编码方式才能进行。可以这么说,byte数组告诉了我们这个字符的内容,而编码方式告诉了我们如何去读这个byte数组才能获得我们需要的信息。什么时候转?一句话——有IO的时候。编码问题主要出现在文件读取,网络传输等,可以说只要有信息传递的地方都存在这个问题。而在Java中,所有信息的获取(发送)已经被抽象为“流”的概念,所以,这就解释了为什么Java的IO中又加入了Reader和Writer。就是为了能让上层直接面对你所需要的信息,即:字符(char);同时,提供统一的接口解决编码问题——想想看如果以上面String的形式来解决编码问题将会是一件多么可怕的事情~一个sample:p lic String dataReader(byte[] bytes, String charset) throws Exception {Reader reader = new InputStreamReader(new ByteArrayInputStream(bytes), charset);String result = “”while( (c = reader.read()) != -1) {result += (char)c;}reader.close();}p lic byte[] dateWriter(String val, String charset) throws Exception {ByteArrayOutputStream out = new ByteArrayOutputStream(1024);Writer writer = new OutputStreamWriter(out, charset);char[] chars = val.toCharArray();for (int i = 0; i & chars. i++) {char c = chars[i];writer.write(c);}writer.flush();writer.close();return out.toByteArray();}上面sample与前面的从String获取byte数组和从byte数组生成String功能是一样的。流的实现虽然复杂,但是因为流抽象,所以可以很容易的替换为其他数据来源(如文件,网络等),而不用更改相关的处理代码。为什么是“?”号编码转换出问题时,最常见的是一个“?”。原因是当出现Java不认识的编码时(即UTF-16不能编码),则对应为一个“\ffd”,对应“?”号。此时再转换为其他部分编码时,则为“3F”。神奇的“ISO-8859-1”其实并不神奇,只是有点特殊而已。此编码只针对单字节(一个byte)进行编码,所以编码具有还原性。即不论何种编码的byte数组,使用此编码编码后,再使用此编码解码,可以还原到原来的byte数组。这是其他编码方式所不具备的。package&com.suypower.chengyu.&&&&public&class&ByteTest&{&&&&&&&&/**&&&&&&*&byte&8&bits&-128&-&+&127&&&&&&*&1&bit&=&1&二进制数据&&&&&&*&1&byte&=&8&bit&&&&&&*&1&字母&=&1&byte&=&8&bit(位)&&&&&&*&1&汉字&=&2&byte&=&16&bit&&&&&&*/&&&&&&public&static&void&main(String[]&args)&{&&&&&&&&&&//&TODO&Auto-generated&method&stub&&&&&&&&&&byte&b1&=&127;&&&&&&&&&&byte&b2&=&-128;&&&&&&&&&&byte&b3&=&'a';&&&&&&&&&&byte&b4&=&'A';&//&一个字母&=&1&byte&=&8&bit&&//&&&&&&byte&b5&='aa';&&这就错了&&//&&&&&&byte&b6&='中';&这就错了&一个汉字&2个字节&16bit&&&&&&&&&&short&s1&=&'啊';&//&一个汉字&2个字节&16bit&short&是&16&bit位的&&//&&&&&&short&s2&=&'汉字';&&//&2个汉字&4个字节&32&bit&int&是32&bit的&&//&&&&&&int&i1&=&'汉字';&&但是&int&是数字类型的&,&char&是&16&bit的&=&2&byte&=&一个汉字&&&&&&&&&&char&c1&=&'汗';&&//&&&&&&byte&转换&string&&&&&&&&&&String&string&=&"中文";&&&&&&&&&&byte&by[]&=&string.getBytes();&&&&&&&&&&String&str&=&new&String(by);&&&&&&&&&&System.out.println("str="+str);&&&&&&}&&&&}&&==================================================================================&&&&[Java-原创]&bit、byte、位、字节、汉字、字符&&bit、byte、位、字节、汉字的关系&&&&&&&&&&&&&&1&bit&&&&&=&1&&二进制数据&&&&&&&&&&1&byte&&=&8&&bit&&&&&&&&&&1&字母&=&1&&byte&=&8&bit&&&&&&&&&&1&汉字&=&2&&byte&=&16&bit&&&&&&1.&bit:位&&&&&&一个二进制数据0或1,是1bit;&&&&2.&byte:字节&&&&&&存储空间的基本计量单位,如:MySQL中定义&VARCHAR(45)&&即是指&45个字节;&&&&&&1&byte&=&8&bit&&&&3.&一个英文字符占一个字节;&&&&&&1&字母&=&1&byte&=&8&bit&&&&4.&一个汉字占2个字节;&&&&&&1&汉字&=&2&byte&=&16&bit&&&&5.&标点符号&&&&&&A&.&&汉字输入状态下,默认为全角输入方式;&&&&&&B&.&&英文输入状态下,默认为半角输入方式;&&&&&&&&C&.&&全角输入方式下,标点符号占2字节;&&&&&&D&.&&半角输入方式下,标点符号占1字节;&&&&&&&&故:汉字输入状态下的字符,占2个字节&(但不排除,自己更改了默认设置);&&&&&&&&&&&&&&英文输入状态下的字符,占1个字节&(但不排除,自己更改了默认设置); &
阅读(9656)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_',
blogTitle:'如何判断字符串中是否有中文',
blogAbstract:'我发现,凡事任何事情,都要留个心,否则的话,就是看完了,也会忘记,我以前看了个笔试题,当时就是涉及到中文字符串的问题,结果,我就直接把人家的答案和总结拿来看了,也没去思考,结果,现在又碰到了这种问题,但是,我却忘得一干二净。
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!&&|&&
LOFTER精选
网易考拉推荐
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
阅读(3457)|
用微信&&“扫一扫”
将文章分享到朋友圈。
用易信&&“扫一扫”
将文章分享到朋友圈。
历史上的今天
loftPermalink:'',
id:'fks_094071',
blogTitle:'Oracle字符串字节长度判断',
blogAbstract:'select LENGTHB(\'你好1\') from dual\r\n5\r\n&\r\n&\r\nwhere lengthb(pkid)=4',
blogTag:'',
blogUrl:'blog/static/',
isPublished:1,
istop:false,
modifyTime:0,
publishTime:5,
permalink:'blog/static/',
commentCount:0,
mainCommentCount:0,
recommendCount:0,
bsrk:-100,
publisherId:0,
recomBlogHome:false,
currentRecomBlog:false,
attachmentsFileIds:[],
groupInfo:{},
friendstatus:'none',
followstatus:'unFollow',
pubSucc:'',
visitorProvince:'',
visitorCity:'',
visitorNewUser:false,
postAddInfo:{},
mset:'000',
remindgoodnightblog:false,
isBlackVisitor:false,
isShowYodaoAd:false,
hostIntro:'',
hmcon:'0',
selfRecomBlogCount:'0',
lofter_single:''
{list a as x}
{if x.moveFrom=='wap'}
{elseif x.moveFrom=='iphone'}
{elseif x.moveFrom=='android'}
{elseif x.moveFrom=='mobile'}
${a.selfIntro|escape}{if great260}${suplement}{/if}
{list a as x}
推荐过这篇日志的人:
{list a as x}
{if !!b&&b.length>0}
他们还推荐了:
{list b as y}
转载记录:
{list d as x}
{list a as x}
{list a as x}
{list a as x}
{list a as x}
{if x_index>4}{break}{/if}
${fn2(x.publishTime,'yyyy-MM-dd HH:mm:ss')}
{list a as x}
{if !!(blogDetail.preBlogPermalink)}
{if !!(blogDetail.nextBlogPermalink)}
{list a as x}
{if defined('newslist')&&newslist.length>0}
{list newslist as x}
{if x_index>7}{break}{/if}
{list a as x}
{var first_option =}
{list x.voteDetailList as voteToOption}
{if voteToOption==1}
{if first_option==false},{/if}&&“${b[voteToOption_index]}”&&
{if (x.role!="-1") },“我是${c[x.role]}”&&{/if}
&&&&&&&&${fn1(x.voteTime)}
{if x.userName==''}{/if}
网易公司版权所有&&
{list x.l as y}
{if defined('wl')}
{list wl as x}{/list}}

我要回帖

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信