截取指定长度文字,超出部分以特定字符代替

简介: 这是在做新闻发布系统时收录的一个简单算法。感觉挺好用的。效果如下(新闻标题):   下面是算法源码: #region 将指定字符串按指定长度进行剪切 /// /// 将指定字符串按指定长度进行剪切 ...

这是在做新闻发布系统时收录的一个简单算法。感觉挺好用的。效果如下(新闻标题):

 

下面是算法源码:

	#region 将指定字符串按指定长度进行剪切
        ///   <summary> 
        ///   将指定字符串按指定长度进行剪切
        ///   </summary> 
        ///   <param   name= "oldStr "> 需要截断的字符串 </param> 
        ///   <param   name= "maxLength "> 字符串的最大长度 </param> 
        ///   <param   name= "endWith "> 超过长度的后缀 </param> 
        ///   <returns> 如果超过长度,返回截断后的新字符串加上后缀,否则,返回原字符串 </returns> 
        public static string StringTruncat(string oldStr, int maxLength, string endWith)
        {
            //判断字符串是否为null或空
            if (string.IsNullOrEmpty(oldStr))
            {
                //   throw   new   NullReferenceException( "原字符串不能为空 "); 
                return oldStr + endWith;
            }

            //判断限制长度是否>=1
            if (maxLength < 1)
            {
                throw new Exception("返回的字符串长度必须大于[0] ");
            }


            if (oldStr.Length > maxLength)
            {
                string strTmp = oldStr.Substring(0, maxLength);
                if (string.IsNullOrEmpty(endWith))
                    return strTmp;
                else
                    return strTmp + endWith;
            }
            return oldStr;
        }
        #endregion


下面是Sample:

<asp:TemplateField HeaderText="新闻标题">
    <ItemTemplate>
        <a href='newscontent.aspx?newsid=<%# Eval("id") %>' target="_blank" title="<%# Eval("title") %>"><%# StringTruncat (Eval("title").ToString(),18,"...") %></a>
    </ItemTemplate>
</asp:TemplateField> 

 

目录
相关文章
|
机器学习/深度学习 并行计算 Linux
PyCharm+Docker:打造最舒适的深度学习炼丹炉
PyCharm+Docker:打造最舒适的深度学习炼丹炉
515 0
|
编解码 安全 计算机视觉
FFMPEG常用命令 音视频合并
FFMPEG常用命令 音视频合并
541 2
|
算法 Java
为什么设置-Xmx4g但是java进程内存占用达到8g?
为什么设置-Xmx4g但是java进程内存占用达到8g?
2080 0
为什么设置-Xmx4g但是java进程内存占用达到8g?
|
缓存 JavaScript 前端开发
往centos中添加字体
往centos中添加字体
339 0
|
SQL 前端开发
枚举工具类
枚举工具类
330 0
使用Swagger 让某些接口不显示在文档
使用Swagger 让某些接口不显示在文档
208 0
Aliyun-RocketMQ查看生产/消费速率
Aliyun-RocketMQ 入门拾遗。
249 0
Aliyun-RocketMQ查看生产/消费速率
|
SQL 安全 关系型数据库
MySQL的delete应该加 limit么 ?
在业务场景要求高的数据库中,对于单条删除和更新操作,在 delete 和 update 后面加 limit 1 绝对是个好习惯。比如,在删除执行中,第一条就命中了删除行,如果 SQL 中有 limit 1;这时就 return 了,否则还会执行完全表扫描才 return。效率不言而喻。
1170 0