JavaScript实现UTF-8编解码

JavaScript实现UTF-8编解码

免费学习推荐:javascript视频教程

首先简单介绍一下UTF-8。UTF-8以字节为单位对Unicode进行编码。UTF-8的特点是对不同范围的字符使用不同长度的编码。对于0x00-0x7F之间的字符,UTF-8编码与ASCII编码完全相同。UTF-8编码的最大长度是6个字节。6字节模板有31个x,即可以容纳31位二进制数字。Unicode的最大码位0x7FFFFFFF也只有31位。

登录后复制

从Unicode到UTF-8的编码方式如下:

Unicode编码(十六进制) UTF-8 字节流(二进制)

000000-00007F0xxxxxxx000080-0007FF110xxxxx 10xxxxxx000800-00FFFF1110xxxx 10xxxxxx 10xxxxxx010000-10FFFF11110xxx10xxxxxx10xxxxxx10xxxxxx

以下是js实现代码,首先是编码

function utf8Encode(inputStr) {  var outputStr = "";    for(var i = 0; i < inputStr.length; i++) {    var temp = inputStr.charCodeAt(i);        //0xxxxxxx    if(temp < 128) {      outputStr += String.fromCharCode(temp);    }    //110xxxxx 10xxxxxx    else if(temp > 6) | 192);      outputStr += String.fromCharCode((temp & 63) | 128);    }    //1110xxxx 10xxxxxx 10xxxxxx    else if(temp > 12) | 224);      outputStr += String.fromCharCode(((temp >> 6) & 63) | 128);      outputStr += String.fromCharCode((temp & 63) | 128);    }    //11110xxx 10xxxxxx 10xxxxxx 10xxxxxx    else {      outputStr += String.fromCharCode((temp >> 18) | 240);      outputStr += String.fromCharCode(((temp >> 12) & 63) | 128);      outputStr += String.fromCharCode(((temp >> 6) & 63) | 128);      outputStr += String.fromCharCode((temp & 63) | 128);    }  }    return outputStr;}

登录后复制

下面是解码

立即学习“Java免费学习笔记(深入)”;

function utf8Decode(inputStr) {  var outputStr = "";  var code1, code2, code3, code4;    for(var i = 0; i < inputStr.length; i++) {    code1 = inputStr.charCodeAt(i);        if(code1 < 128) {      outputStr += String.fromCharCode(code1);    }    else if(code1 < 224) {      code2 = inputStr.charCodeAt(++i);      outputStr += String.fromCharCode(((code1 & 31) << 6) | (code2 & 63));    }    else if(code1 < 240) {      code2 = inputStr.charCodeAt(++i);      code3 = inputStr.charCodeAt(++i);      outputStr += String.fromCharCode(((code1 & 15) << 12) | ((code2 & 63) << 6) | (code3 & 63));    }    else {      code2 = inputStr.charCodeAt(++i);      code3 = inputStr.charCodeAt(++i);      code4 = inputStr.charCodeAt(++i);      outputStr += String.fromCharCode(((code1 & 7) << 18) | ((code2 & 63) << 12) |((code3 & 63) << 6) | (code2 & 63));    }  }    return outputStr;}

登录后复制

以上!

相关免费学习推荐:javascript(视频)

以上就是JavaScript实现UTF-8编解码的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2718436.html

(0)
上一篇 2025年3月7日 22:15:16
下一篇 2025年3月6日 16:10:51

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论