JavaScript获取字符串实际长度(包含中英文)
2022-06-21 19:51:06 来源:易采站长站 作者:
日常开发过程中,经常会遇到需要计算字符串的实际长度(包含中英文),今天整理下我平时使用的方法:
方法一:使用charCodeAt()来判断字符编码
charCodeAt()>
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script> /** * 获取字符串实际长度(包含中英文) * @param str 要获得长度的字符串 */ var zfc = {}; zfc.getStringLength = function (str) { var realLength = 0, len = str.length, charCode = -1; for (var i = 0; i < len; i++) { charCode = str.charCodeAt(i); if (charCode >= 0 && charCode <= 128) realLength += 1; else realLength += 2; } return realLength; }; console.log(zfc.getStringLength('aaa获取字符sfdsf串实际长度(包含中英文)sdfdsf')) </script> </head> <body> </body> </html>
方法二:>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script>
/**
* 获取字符串实际长度(包含中英文)
* @param str 要获得长度的字符串
*/
var zfc = {};
zfc.getStringLength = function (str) {
var len = str.length;
var realLength = 0;
for (var i = 0; i < len; i++) {
if ((str.charCodeAt(i) & 0xff00) != 0) {
realLength++;
}
realLength++;
}
return realLength;
};
console.log(zfc.getStringLength('aaa获取字符sfdsf串实际长度(包含中英文)sdfdsf'))
</script>
</head>
<body>
</body>
</html>
方法三: 先把中文替换成两个字节的英文,再计算长度(推荐使用)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script>
/**
* 获取字符串实际长度(包含中英文)
* @param str 要获得长度的字符串
*/
var zfc = {};
zfc.getStringLength = function (str) {
return str.replace(/[\u0391-\uFFE5]/g, 'aa').length;
};
console.log(zfc.getStringLength('aaa获取字符sfdsf串实际长度(包含中英文)sdfdsf'))
</script>
</head>
<body>
</body>
</html>
到此这篇关于JavaScript获取字符串实际长度的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持易采站长站。
如有侵权,请联系QQ:279390809 电话:15144810328
最新图文推荐
相关文章
-
Vue+elementUI实现多图片上传与回显功能(含回显后继续上传或删除
最近有使用vue+elementUI实现多图片上传的需求,遂做此纪录。 本次主要写一下前端的实现细节,至于后台以Multipart[ ]数组接收即可,不再赘述,网上一搜大把文章可供参考。 本次使用2020-03-23
-
Vue-router 报错NavigationDuplicated的解决方法
版本:3.1.x 报错原因: 使用push()、replace()进行导航时,不能重复导航到当前路由。 解决办法: 方法1:在定义路由的文件中router/index.js const originalPush = VueRouter.prototype.pushVueRouter.protot2020-03-31