asp.net---高亮显示搜索关键字


前端代码
<asp:DataList ID="DataList1" runat="server"  >
     <ItemTemplate>
       <li class=Sub>
          <a href="Leave.aspx?Name=<%#Eval("Uid")%>"><span><%#Eval("Uid") %></span></a>
          <ul class=list-unstyled>
              <li>
                  <a href="ShowWords.aspx?subjectID=<%#Eval("ID")%>">
                         <%#HightLight((string)Eval("Subject"),txtSearch) %><!--这里使用自定义方法实现高亮显示搜索关键字-->
                  </a>
              </li>
              <li class=DateTime>
                  <%#Eval("leaveTime")%>
              </li>
          </ul>
       </li>
     </ItemTemplate>
</asp:DataList>

后台代码:

protected string HightLight(string strKey,string keyword)//strKey为搜索出的内容,keyword为搜索的关键字
        {
            if (keyword == ""||keyword==null)//如果搜索关键字为空
            {
                return strKey;
            }
            if(strKey.IndexOf(keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1))>-1)//如果搜索的关键字在原文中存在(这里区分大小写)
            {
                //替换原文中的关键字
                string strReturn = strKey.Replace(keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1), "<span class='hightlightTxtSearch'>" + keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1) + "</span>");
                return strReturn;
            }
            else if(strKey.ToUpper().IndexOf(keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1).ToUpper()) >-1)//将原文与关键字都变为大写,如果能够匹配
            {
                //替换原文中的关键字
                keyword = strKey.Substring(strKey.ToUpper().IndexOf(keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1).ToUpper()), keyword.Substring(keyword.IndexOf("'") + 1, keyword.LastIndexOf("'") - 1).Length);
                string strReturn = strKey.Replace(keyword, "<span class='hightlightTxtSearch'>" + keyword+ "</span>");
                return strReturn;
            }
            else
            {
                return strKey;
            }
        }


预览效果:




  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值