前端代码
<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;
}
}
预览效果: