- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想过滤我的 json,我尝试使用通配符“%”模拟简单的 mysql 运算符“like”,但使用一个……某种“技巧”。
我们有一些元素:
var items =
[
{id: 1,name: "Breaking Bad"},
{id: 2,name : "Bates Motel"}
]
当我将 PHP 与 MySQL 结合使用时,我将用户输入中的每个空格替换为“%”。因此,当用户键入“b ba”时,查询如下所示:
$this->db->query("SELECT * FROM items WHERE name LIKE '%b%ba% ");
用户获得项目:“Breaking Bad”。我想用 javascript 和 json 模拟相同的行为。
我最接近的实现是这样的:
this.search = function() {
var query = $.trim($('.player-search').val())
query = query.toUpperCase()
$.grep(that.items, function(v) {
if(that.filter(v.name,query) === true) {
$('.player-serial[data-id="'+v.id+'"]').fadeIn(200)
} else {
$('.player-serial[data-id="'+v.id+'"]').fadeOut(200)
}
})
}
this.filter = function(word,query) {
var tmp = query.toUpperCase().split(" "),
n = tmp.length,
i = 0
for(var k in tmp) {
word.toUpperCase().indexOf(tmp[k]) >= 0 && ++i
}
return (i == n) ? true : false
}
这种方式有一个可怕的错误,当用户键入“b ba”时,用户会得到“Breaking Bad”和“Bates Motel”,因为“Bates”一词包含“b”和“ba”。
在我尝试再次编写它之前,我想问一下是否有更好/更智能的方法来根据需要过滤 json?可能是我要重新发明轮子吧。
最佳答案
你可以使用$.grep()
, String.prototype.match()
, Array.prototype.every()
, String.prototype.slice()
var items = [{
id: 1,
name: "Breaking Bad"
}, {
id: 2,
name: "Bates Motel"
}];
var query = "b ba";
var res = $.grep(items, function(v) {
// if space character included in query match first word to
// first word of `v.name`, last word to last word in `v.name`
if (/\s/.test(query)) {
var curr = v.name.match(/\w+/g).map(function(_q) {
return _q.toLowerCase()
});
var q = query.match(/\w+/g);
if (q.every(function(val, index) {
return val === curr[index].slice(0, val.length)
})) return true
} else {
if (q.toLowerCase() === v.name.toLowerCase().slice(0, q.length)) {
return true
}
}
});
console.log(res[0])
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js">
</script>
关于javascript - 过滤json类似mysql "like"操作符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37635900/
算数运算符 a = 1 + 1 // 2 a = 10 - 5 // 5 a = 10 / 5 // 2 a = 10 / 0 // js中除以0不会报错,结果是Infinity a = 2*2
操作符 分类 算术操作符 移位操作符 位操作符 赋值操作符 单目操作符 关系操作符 逻辑操作符 条件操作符 逗号表达式 下标引用、
大家可以与Java中的 == 操作符相互印证一下,加深一下对引用和对象的理解。原问题: Python为什么直接运行和在命令行运行同样语句但结果却不同,他们的缓存机制不同吗? 其实,高票答案已经说得
a: 1---2-3-4--5---6 b: ------T--------- o: ------1234-5---6 使用RxJS,有没有什么算子可以完成上图?我有一个流 A,它是一个随机的事件流,
请查看下面的代码并帮助我理解这个概念equals 方法仅比较对象的值,而 == 运算符比较对象的引用,那么为什么在代码中 == 运算符返回 false,即使创建了两个单独的对象 Ex Obj1
我在love2d引擎上做了一个无关紧要的lua控制台。我正在尝试升级元表以实现更多功能(配对功能,更改另一个表上的元表而不是目标表等),我正在制作的插件之一是 __changeindex修改现有索引时
今天分享一个比较少见的用法,那就是 Python 是有 ,= 这种用法的,至于是它是否称得上操作符,这个不重要。 咱们先一起回顾一下逗号相关的用法吧: 1,元组的组成部分 没有逗号的括号,
按照要求进行的排序: 复制代码 代码如下: #!/bin/perl @number=qw/5 10 15 3 2 4 8 6 /; my @d
请注意,UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每个 SELECT 语句中的列的顺序必须相同。 SQL UNION 语法 下面的 SQL
运算符“!”有什么区别?和“-z”应用于字符串? #Example 1 if [ ! STRING ]; then ... #Example 2 if [ -z STRING ]; then ...
我想定义一个形式为 x /==> y 的新运算符, 在哪里 运营商/==>被视为例如/@ Map 的运营商, 和 翻译成 MyFunction[x, y] .有一个重要的方面:我 希望结果运算符在前端
我有一个Bitset类,用于存储chars的vector,并且我希望每当使用cout bit = std::vector ((X + 7)/ 8); 上市: / *构造函数* / friend st
我事先确实在这里找到了一个确切的问题,但我没有相同的问题原因(或者至少我认为是这样)。我的 AnimatedSprite类有 Timer成员,使其不可复制(明确删除了复制 ctor 和 operato
这个问题已经有答案了: What does C++ struct syntax "a : b" mean (5 个回答) ":" (colon) in C struct - what does it
我想过滤我的 json,我尝试使用通配符“%”模拟简单的 mysql 运算符“like”,但使用一个……某种“技巧”。 我们有一些元素: var items = [ {id: 1,name:
我正在使用 Flink v.1.4.0。 我希望能够在 Flink UI 中命名运算符。我知道要这样做,我只需要在 DataSet 或 DataStream 上使用 .name() 方法。例如,像这样
在我的任务中,我被要求创建 Product 类,我已经完成了除“非成员 IO 运算符”之外的所有实现。我发现这个问题非常模糊,它要求我重载 >运算符与 ostream 和 istream 一起从控制台
我想要一个 QTableWidget带有定制的某些电池 QProgressBar s,我希望可以对包含这些的列进行排序。 我的定制QProgressBar继承自 QProgressBar和 QTabl
这在 Ruby 中如何实现?不重复变量就可以做到吗?Javascript: b = a || 7 如果 a 不是 0 则分配 a 否则分配 7 一个具体情况是将 date.wday 转换为 7,如果它
在使用 withLatestFrom 时,我正在努力将参数传递给选择器,这是之前从加载操作有效负载映射的 loadLocalSubServices$: Observable = this.action
我是一名优秀的程序员,十分优秀!