zoukankan      html  css  js  c++  java
  • 类似于百度显示搜索结果时将关键字标红

    /**
     * 渲染匹配的子串样式
     * @param  {[type]} str    [description]搜索结果
     * @param  {[type]} substr [description]搜索关键字 以空格隔开
     * @return {[type]}        [description]返回将搜索结果中的关键字标红的文本
     */
    function renderMatchSubstring(str, substr)
    {
    	var substrList = substr.split(/s+/);
    	var regStr = "(" + substrList.join(")|(") + ")";
    	var reg = new RegExp(regStr,"g");
    	var matchResult = str.match(reg);
    	for(index in matchResult)
    	{
    		var regS = new RegExp("[^</](" + matchResult[index] + ")","g");
    		str = str.replace(regS,"<span style='color:red;font-weight:bold'>$1</span>");
    	}
    	return str;
    }
    

     

    关键在于 如果原文档是存在样式标签之类的需要避开 比如 原文本中含有  <p></p> 但是搜索的关键字 也有p 那么测试需要避开<p>以免样式错乱。本方法还未彻底完善。

  • 相关阅读:
    tcl tk lappend
    file join
    [转载]强指针和弱指针
    DisplayHardware
    Android 十大调试方法
    C语言程序的外部变量与函数
    DisplayHardware
    Android 十大调试方法
    wifi连接流程分析
    [转载]强指针和弱指针
  • 原文地址:https://www.cnblogs.com/potatog/p/9314021.html
Copyright © 2011-2022 走看看