考虑到有许多浏览器不兼容CSS,text-overflow的方式剪裁字符串加上“...”,网上也有提供全兼容的解决办法,但怎么样都没有后台处理字符串的方式来的直接。
下面我就给出后台处理的代码:
/// <summary>
/// 提供字符串操作
/// </summary>
public static class StringHelper
{
/// <summary>
/// 按照指定的长度剪裁字符串
/// </summary>
/// <param name="originalString">原始字符串</param>
/// <param name="length">剪裁长度</param>
/// <returns>剪裁后的字符串</returns>
public static string CropString(string originalString, int length)
{
if (length < originalString.Length)
{
return originalString.Substring(0, length) + "...";
}
else return originalString;
}
/// <summary>
/// 按照指定的长度可区分中英文剪裁字符串
/// </summary>
/// <param name="originalString">原始字符串</param>
/// <param name="length">剪裁长度</param>
/// <param name="isSeparate">是否区分中英文</param>
/// <returns>剪裁后的字符串</returns>
public static string CropString(string originalString, int length, bool isSeparate)
{
if (!isSeparate)
{
return CropString(originalString, length);
}
else
{
int len = length;
for (int i = 0; i < (length > originalString.Length ? originalString.Length : length); i++)
{
Regex rx = new Regex("^[\u4e00-\u9fa5]$");
if (!rx.IsMatch(originalString[i].ToString()))
{
len++;
}
}
return CropString(originalString, len);
}
}
}
如果区分了中英文,那么显示的长字符串宽度基本上差不多。
逻辑:
- 遍历整个字符串;
- 提取每个字符,判断是否是中文字符;
- 如果不是,则将截取的长度加1,否则继续遍历;
- 循环结束,按照新的长度裁剪字符串;