JSON 对象内的 Javascript 搜索

IT技术 javascript jquery jsonp json
2021-01-15 07:13:26

我的应用程序中有一个 JSON 字符串/对象。

{"list": [
    {"name":"my Name","id":12,"type":"car owner"},
    {"name":"my Name2","id":13,"type":"car owner2"},
    {"name":"my Name4","id":14,"type":"car owner3"},
    {"name":"my Name4","id":15,"type":"car owner5"}
]}

我的应用程序中有一个过滤器框,当我在该框中输入名称时,我们必须过滤对象并显示结果。

例如,如果用户键入“name”并点击搜索,那么我们必须在 JSON 对象中搜索全名并返回数组,就像 MySQL 搜索一样......

我的问题是用字符串过滤json对象并返回数组....

6个回答

您可以循环遍历数组并找到匹配项:

var results = [];
var searchField = "name";
var searchVal = "my Name";
for (var i=0 ; i < obj.list.length ; i++)
{
    if (obj.list[i][searchField] == searchVal) {
        results.push(obj.list[i]);
    }
}

如果您的问题是,是否有一些内置的东西可以为您搜索,那么不,没有。您基本上使用正则表达式String#indexOf正则表达式遍历数组来测试字符串。

对于循环,您至少有三个选择:

  1. 一个无聊的老for循环。

  2. 在启用 ES5 的环境(或带有 shim)中,Array#filter.

  3. 由于您使用jQuery jQuery.map

无聊的旧for循环示例:

function search(source, name) {
    var results = [];
    var index;
    var entry;

    name = name.toUpperCase();
    for (index = 0; index < source.length; ++index) {
        entry = source[index];
        if (entry && entry.name && entry.name.toUpperCase().indexOf(name) !== -1) {
            results.push(entry);
        }
    }

    return results;
}

您可以使用obj.listassource和所需的名称片段作为name.

或者,如果有可能出现空白条目或没有名称的条目,请将if更改为:

        if (entry && entry.name && entry.name.toUpperCase().indexOf(name) !== -1) {

Array#filter 例子:

function search(source, name) {
    var results;

    name = name.toUpperCase();
    results = source.filter(function(entry) {
        return entry.name.toUpperCase().indexOf(name) !== -1;
    });
    return results;
}

再一次,如果有任何机会出现空白条目(例如,undefined与丢失相反;filter将跳过丢失的条目),将内部返回更改为:

        return entry && entry.name && entry.name.toUpperCase().indexOf(name) !== -1;

jQuery.map示例(这里我假设jQuery=$通常是这种情况;如果您正在使用,请更改$):jQuerynoConflict

function search(source, name) {
    var results;

    name = name.toUpperCase();
    results = $.map(source, function(entry) {
        var match = entry.name.toUpperCase().indexOf(name) !== -1;
        return match ? entry : null;
    });
    return results;
}

(再次,entry && entry.name &&如有必要在那里添加。)

我认为这个答案比接受的答案要详细一些。
2021-03-18 07:13:26
困惑为什么source在这里的最后一个函数使用$.map正在被使用,因为source甚至没有被根本在于所使用search的功能,什么是它的参数的意义呢?
2021-03-19 07:13:26
@Skillzore 就 Iknow 而言,几乎没有什么事情是重要的,尤其是在现代环境中。但即使是旧的处理(比如)函数调用也非常快。
2021-03-24 07:13:26
@SolomonClosson:是的,确实重新通过了source,已修复。不过,它是一个数组;list在的问题。
2021-03-26 07:13:26
我想你忘了在这里source传入$.mapjQuery 函数。否则,您什么也没有映射。此外,source需要是要映射的数组,而source在这种情况下object不是数组,因此需要$.makeArray先将其传递给
2021-03-27 07:13:26

您可以简单地将数据保存在一个变量中,然后使用 JavaScript 的 find(获取单个记录对象)或 filter(获取单个记录数组)方法。

例如 :-

let data = {
 "list": [
   {"name":"my Name","id":12,"type":"car owner"},
   {"name":"my Name2","id":13,"type":"car owner2"},
   {"name":"my Name4","id":14,"type":"car owner3"},
   {"name":"my Name4","id":15,"type":"car owner5"}
]}

现在使用以下命令 onkeyup 或输入

获取单个对象

data.list.find( record => record.name === "my Name")

获取单个数组对象

data.list.filter( record => record.name === "my Name")

使用PaulGuojSQL,一个使用 javascript 的类似 SQL 的数据库。例如:

var db = new jSQL();
db.create('dbname', testListData).use('dbname');
var data = db.select('*').where(function(o) {
    return o.name == 'Jacking';
}).listAll();

我调整了正则表达式以使用 JSON。

首先,将 JSON 对象字符串化。然后,您需要存储匹配子字符串的开头和长度。例如:

"matched".search("ch") // yields 3

对于 JSON 字符串,这完全相同(除非您明确搜索逗号和大括号,在这种情况下,我建议您在执行正则表达式之前先对 JSON 对象进行一些转换(即认为:、{、})。

接下来,您需要重建 JSON 对象。我编写的算法通过从匹配索引递归地返回来检测 JSON 语法来做到这一点。例如,伪代码可能如下所示:

find the next key preceding the match index, call this theKey
then find the number of all occurrences of this key preceding theKey, call this theNumber
using the number of occurrences of all keys with same name as theKey up to position of theKey, traverse the object until keys named theKey has been discovered theNumber times
return this object called parentChain

有了这些信息,就可以使用正则表达式来过滤 JSON 对象以返回键、值和父对象链。

您可以在http://json.spiritway.co/ 上查看我编写的库和代码

嗨,这个答案很旧,但我喜欢它的精神。http 链接似乎已过时。我在哪里可以找到你的这个图书馆?
2021-03-28 07:13:26