前端实现对象数组的关键字搜索

在前后端分离的项目开发过程中,我们时常会遇到从后端取出来的数据对象需要在前端操作的情况,比如这里所说的对象关键字搜索。
下面就是关键字搜索的一个简单的实现:

function escapeRegExpWildcards(searchStr) {
	const regExp = /([\(\[\{\\\^\$\}\]\)\?\*\+\.])/img;
		if (searchStr && regExp.test(searchStr)) {
		return searchStr.replace(regExp, '\\$1');
	}
	return searchStr;
}

function searchByKeywords(keywords, searchArr) {
	const keywordsExp = new RegExp(".*?" + escapeRegExpWildcards(keywords) + ".*?", "img");
	return searchArr.filter(v => (keywordsExp.test(v.fruitName) || keywordsExp.test(v.fruitCode)));
}

方法**escapeRegExpWildcards(searchStr)**是用于替换正则表达式中的特殊字符,在构建表达式的时候需要转义这些特殊字符,否则会导致以下测试用例中的"黑*凤梨"无法得到结果。当然也可以不用做这样的转义,前端页面的关键字搜索也就会支持正则表达式搜索,不过在目标对象中包含此类特殊字符时就需要前端提供的值中自行转义。以下是正则表达式中的特殊字符:

正则表达式特殊字符列表
以下是测试代码:
测试用的水果对象数组

const fruitArr = [ 
	{ "fruitCode":"APPLE", "fruitName": "苹果" }, 
	{ "fruitCode":"BANANA", "fruitName": "香蕉" }, 
	{ "fruitCode":"PINEAPPLE", "fruitName": "黑*凤梨" } 
];

查询1:

console.log(JSON.stringify(searchByKeywords("苹果", fruitArr)));

运行结果
测试1结果
查询2:

console.log(JSON.stringify(searchByKeywords("APPLE", fruitArr)));

运行结果
测试2结果
查询3:

console.log(JSON.stringify(searchByKeywords("黑*凤梨", fruitArr)));

运行结果
测试3结果

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

澜冰-Tonly

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值