自动匹配关键字并且标红

1. 单关键字匹配

若只需匹配 搜索内容  可以写的简单一些,代码如下:

if (name != null && name.contains(mKeyWord)) {    
           int index = name.indexOf(mKeyWord);    
           int len = mKeyWord.length();    
           Spanned temp = Html.fromHtml(name.substring(0, index)    
                   + "<font color=#FF0000>"    
                   + name.substring(index, index + len) + "</font>"    
                   + name.substring(index + len, name.length()));    
  
           holder.tv_name.setText(temp);    
       } else {    
           holder.tv_name.setText(name);    
}  

上面的name是你要显示整个item内容,  mKeyWord 是搜索的关键字  holder.tv_name 是当前textview控件

2.多关键字匹配

有的时候我们做搜索的时候 是需要将用户输入的关键字在服务端做拆分,拆分为多个关键字去搜索。那么服务端返回数据的时候关键字被拆分为多个。也就是返回的是一个关键字数组。

这种情况我们在客户端做  关键字匹配的时候就要写一个算法,将段落中的多个关键字全部匹配并且标出来。

代码如下:

adapter里面逻辑:

/** 
  name   是item显示内容  当前item显示字符串内容 
   keyList 是指存放 多个关键字的list集合 
*/    
StringBuffer str = new StringBuffer("");  
str =  Utils.addChild(name, keyList, str);  
holder.contentTv.setText(Html.fromHtml(str.toString())); 

  

/** 
 * 多关键字查询表红,避免后面的关键字成为特殊的HTML语言代码 
 * @param str       检索结果 
 * @param inputs    关键字集合 
 * @param resStr    表红后的结果 
 */  
public static StringBuffer addChild(String str,List<String> inputs,StringBuffer resStr){  
    int index=str.length();//用来做为标识,判断关键字的下标  
    String next="";//保存str中最先找到的关键字  
    for (int i = inputs.size() -1 ; i>= 0;i--) {  
        String theNext=inputs.get(i);  
        int theIndex=str.indexOf(theNext);  
        if(theIndex==-1){//过滤掉无效关键字  
            inputs.remove(i);  
        }else if(theIndex<index){  
            index=theIndex;//替换下标  
            next=theNext;  
        }  
    }  
  
    //如果条件成立,表示串中已经没有可以被替换的关键字,否则递归处理  
    if(index==str.length()){  
        resStr.append(str);  
    }else{  
        resStr.append(str.substring(0,index));  
        resStr.append("<font color=‘#FF0000‘>"+str.substring(index,index+next.length())+"</font>");  
        String str1=str.substring(index+next.length(),str.length());  
        addChild(str1,inputs,resStr);//剩余的字符串继续替换  
    }  
    return resStr;  
}  

  

  

时间: 2024-10-11 21:17:47

自动匹配关键字并且标红的相关文章

android 搜索自动匹配关键字并且标红

这个效果主要是为了着重表现搜索关键字的 . 1. 单关键字匹配 若只需匹配 搜索内容  可以写的简单一些,代码如下: if (name != null && name.contains(mKeyWord)) { int index = name.indexOf(mKeyWord); int len = mKeyWord.length(); Spanned temp = Html.fromHtml(name.substring(0, index) + "<font color

JS正则对象 RegExp(有变量的时候使用),用来匹配搜索关键字(标红)

1,平常我们写js正则规则的时候,一般是这样写: var reg = /abc/; 然而,这样写的话,如果abc是一个变量这样就不行,我们需要下面这种写法: var abc = "汉字";var reg = new RegExp(abc, 'g');//g 全局匹配 2, 搜索关键字,让关键字标红: // class='text' :这个类中的文字 $('.text').each(function () {// 关键字标红 var reg = new RegExp($sea, 'g')

android 自动匹配文本 AutoCompleteTextView /MultiAutoCompleteTextView

AutoCompleteTextView:每个文本框只能匹配一次 MultiAutoCompleteTextView:能以分隔符为分割点多次匹配 1 //AutoComplete 的 XML示例 2 <AutoCompleteTextView 3 android:completionThreshold="3" //输入数达到3时开始显示提示 4 android:id="@+id/autoCompleteTextView1" 5 android:layout_w

自动匹配输入的内容(AutoCompleteTextView及MultiAutoCompleteTextView)

自动匹配输入的内容 AutoCompleteTextView 1.功能动态匹配输入的内容,如百度搜索引擎当输入文本时,可以根据内容显示匹配的热门信息 2.属性:android:completionThresh=“2”//设置输入多少字符时匹配 AutoCompleteTextView: 适配器应用:适配器的意思就是用数据源去匹配已有的数据. 第一步:初始化控件private AutoCompleteTextView acTextView; 第二步:需要一个适配器ArrayAdapter<Stri

Android控件之MultiAutoCompleteTextView(自动匹配输入的内容)

一.功能 可支持选择多个值(在多次输入的情况下),分别用分隔符分开,并且在每个值选中的时候再次输入值时会自动去匹配,可用在发送短信,发邮件时选择联系人这种类型中 二.独特属性 android:completionThreshold = "2"    ——设置输入多少字符时自动匹配 三.设置分隔符 mtxt.setTokenizer(new MultiAutoCompleteTextView.CommaTokenizer());——设置以逗号作为分隔符 四.代码演示 <Linear

Android控件之AutoCompleteTextView(自动匹配输入的内容)

一.功能 动态匹配输入的内容,如百度搜索引擎当输入文本时,可以根据内容显示匹配的热门信息 二.独特属性 android:completionThreshold = "2"    ——设置输入多少字符时自动匹配 三.代码演示 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" an

CComboBox自动匹配

void CLoadPhotoDlg::OnCbnEditchangeCombo1() {  // TODO: 在此添加控件通知处理程序代码  UpdateData(TRUE);  CComboBox *ctr_goodsName = (CComboBox *)GetDlgItem(IDC_COMBO1); //清空列表  for (int i=(ctr_goodsName->GetCount()-1);i>-1;i--)  {   ctr_goodsName->DeleteString

下拉框(可输入+自动匹配)

实现可输入+带自动匹配功能的下拉框,我试过以下几种方法: 1.直接使用h5的新标签<datalist>,对应demo如下: <input list="browsers"> <datalist id="browsers"> <option value="Internet Explorer"> <option value="Firefox"> <option val

javaScript实现修改输入框之后标红

<html> <title>实现标红</title> <script type="text/javascript">  function edit_save(value1){    for(var i=1;i<4;i++){     if(value1==1)       document.getElementById('input'+i).disabled="";     else       document