前端模糊匹配方式,前端正则模糊匹配

本文介绍前端开发中实现模糊搜索的方法,包括使用正则表达式的匹配和字符串的indexOf方法,通过实例展示了如何在输入框中实时进行模糊匹配。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端的匹配方式有很多这里简单提供模糊匹配方式:使用 RegExp 函数 正则表达式来进行匹配

  1. 正则表达式
var list = ['nai','43q','5xn']
var keyWord = 'n'
var arr = []
var reg = new RegExp(keyWord)

for(var i = 0; i < list.length; i++) {
	if(list[i].match(reg)) {
		 arr.push(list[i]);
	}
}
return arr;

var list = ['nai','43q','5xn']
var keyWord = 'n'
var arr = []
var reg = new RegExp(keyWord)

list.forEach((item,index) => {
	if(list[index].match(reg)) {
		 arr.push(list[index]);
	}
})
console.log(arr);

forEach、for in 、 for of三者的区别: https://blog.youkuaiyun.com/one_girl/article/details/80192899

  • 将此模糊匹配放入输入框监听事件中,就可以做到动态的模糊匹配了
  // 输入框操作
  public changeInput = (e: any) => {
    const value = e.target.value
    this.setState(() => ({ userName: value }))
    // this.getPerson({ name: value })

    // 模糊匹配人名
    let certsList: any[] = []
    let reg = new RegExp(value)
    this.state.certsListAll.forEach((item,index)=>{
      if (this.state.certsListAll[index].userName.match(reg)) {
        certsList.push(this.state.certsListAll[index])
      }
    })
    this.setState(() => ({ certsList: certsList }))
  }

网上还发现了另一种方法

  1. 字符串方法indexOf
var arr = [];
for(var i=0;i<list.length;i++){
    //如果字符串中不包含目标字符会返回-1
    if(list[i].indexOf(keyWord)>=0){
        arr.push(list[i]);
    }
}
return arr;

正则表达式更多参考:

{JS}JavaScript使用正则表达式 https://blog.youkuaiyun.com/grueclan/article/details/2153960

https://blog.youkuaiyun.com/weixin_45788388/article/details/105842615

MySQL 正则表达式(REGEXP)https://blog.youkuaiyun.com/qq_36761831/article/details/82862135

https://blog.youkuaiyun.com/weixin_41360448/article/details/81537577

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值