博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js中按字节截取字符串
阅读量:4223 次
发布时间:2019-05-26

本文共 1790 字,大约阅读时间需要 5 分钟。

功能:在网页中显示过长的字符串,截取指定长度,结尾添加省略号。
例如:
testStr = "测试1字符串";
autoAddEllipsis(testStr, 1); // "测..."
autoAddEllipsis(testStr, 2); // "测..."
autoAddEllipsis(testStr, 3); // "测..."
autoAddEllipsis(testStr, 4); // "测试..."
autoAddEllipsis(testStr, 5); // "测试1..."
autoAddEllipsis(testStr, 6); // "测试1..."
autoAddEllipsis(testStr, 7); // "测试1字..."
代码如下,其中全角半角判断部分isFull()的逻辑偷懒了,有特殊符号需求的可以自己定制。
/*  * 处理过长的字符串,截取并添加省略号  * 注:半角长度为1,全角长度为2  *  * pStr:字符串  * pLen:截取长度  *  * return: 截取后的字符串  */ function autoAddEllipsis(pStr, pLen) {
var _ret = cutString(pStr, pLen); var _cutFlag = _ret.cutflag; var _cutStringn = _ret.cutstring; if ("1" == _cutFlag) {
return _cutStringn + "..."; } else {
return _cutStringn; } } /* * 取得指定长度的字符串 * 注:半角长度为1,全角长度为2 * * pStr:字符串 * pLen:截取长度 * * return: 截取后的字符串 */ function cutString(pStr, pLen) {
// 原字符串长度 var _strLen = pStr.length; var _tmpCode; var _cutString; // 默认情况下,返回的字符串是原字符串的一部分 var _cutFlag = "1"; var _lenCount = 0; var _ret = false; if (_strLen <= pLen/2) {
_cutString = pStr; _ret = true; } if (!_ret) {
for (var i = 0; i < _strLen ; i++ ) {
if (isFull(pStr.charAt(i))) {
_lenCount += 2; } else {
_lenCount += 1; } if (_lenCount > pLen) {
_cutString = pStr.substring(0, i); _ret = true; break; } else if (_lenCount == pLen) {
_cutString = pStr.substring(0, i + 1); _ret = true; break; } } } if (!_ret) {
_cutString = pStr; _ret = true; } if (_cutString.length == _strLen) {
_cutFlag = "0"; } return {"cutstring":_cutString, "cutflag":_cutFlag}; } /* * 判断是否为全角 * * pChar:长度为1的字符串 * return: true:全角 * false:半角 */ function isFull (pChar) {
if ((pChar.charCodeAt(0) > 128)) {
return true; } else {
return false; } }

转载地址:http://zfgmi.baihongyu.com/

你可能感兴趣的文章
《浪潮之巅》4计算机工业的生态链
查看>>
《浪潮之巅》5奔腾的芯 英特尔公司
查看>>
python语言程序设计基础笔记(三)从题目到方案
查看>>
读取txt文件出现出现多余空行问题
查看>>
从理论到实践开发自己的聊天机器人
查看>>
@***装饰器(python)
查看>>
2.3 WSN的MAC协议
查看>>
栈与队列的应用——计算表达式的值
查看>>
BFS——求矩阵中“块”的个数
查看>>
BFS——走迷宫的最小步数
查看>>
并查集——好朋友
查看>>
关键路径
查看>>
Web前端学习笔记——JavaScript之事件详解
查看>>
Web前端学习笔记——JavaScript之事件、创建元素、节点操作
查看>>
Web前端学习笔记——JavaScript之正则表达式、伪数组、垃圾回收
查看>>
Web前端学习笔记——JavaScript 之继承、函数进阶
查看>>
Web前端学习笔记——JavaScript之面向对象游戏案例:贪吃蛇
查看>>
不做单元测试?小心得不偿失!嵌入式系统单元测试工具,自动生成测试用例
查看>>
一种实用的联网汽车无线攻击方法及车载安全协议
查看>>
光靠欺骗检测是不够的:对抗多目标跟踪的攻击
查看>>