javascript - Node 部分搜索

标签 javascript node.js regex search partial

我在网上找到了一个教程,有一个简单的方法来进行部分搜索。我想做的是,当有人只写 geor 时,它会找到一个名为 george

的用户
db.stores.find({storeName : {$regex : /Geor/}}).pretty()

但我不知道如何在我的搜索中实现它。我尝试了一些方法,但一切都以错误结束。

这是我的 Controller :

/**
 * GET /admin/users/:page
 * Find users
 */
exports.findUsers = (req, res, next) => {
  const perPage = 13
  const page = Number(req.params.page) || 1

  var query = {};

  const possibleQueryProps = [{
      "key": "id",
      "queryKey": "_id"
    },
    {
      "key": "email",
      "queryKey": "email"
    },
    {
      "key": "firstname",
      "queryKey": "profile.firstname"
    },
    {
      "key": "lastname",
      "queryKey": "profile.lastname"
    },
    {
      "key": "location",
      "queryKey": "profile.location"
    },
    {
      "key": "status",
      "queryKey": "profile.status"
    }
  ];

  possibleQueryProps.forEach(prop => {
    if (req.query[prop.key]) {
      query[prop.queryKey] = req.query[prop.key];
    }
  });
  console.log(query)
  User
    .find(query)
    .skip((perPage * page) - perPage)
    .limit(perPage)
    .exec(function (err, users) {
      User.countDocuments(query).exec(function (err, count) {
        if (err) return next(err)
        res.render('admin/users', {
          layout: "admin",
          users: users,
          query: req.query,
          active: {
            users: true
          },
          current: page,
          pages: Math.ceil(count / perPage),
          helpers,
          pagesArr: Array.from(Array(((Math.ceil(count / perPage)))).keys()).map(i => 1 + i),
          pagination: core.pagination(page, (Math.ceil(count / perPage))),
        })
      })
    })
};

如果您有任何建议,我将不胜感激。

最佳答案

我认为它会起作用:

possibleQueryProps.forEach(prop => {
  if (req.query[prop.key]) {
    query[prop.queryKey] = {$regex : new RegExp('.*' + req.query[prop.key] + '.*')};
  }
});

关于javascript - Node 部分搜索,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56911776/

相关文章:

node.js - 在 Jade 中创建内联元素的简洁方法是什么

node.js - 使用 Google 授权构建和保护 Angular 和 Node Rest API

regex - 用于删除 JSTL 标记中的特殊字符的正则表达式

regex - 带有可选分隔符的最佳 UUID RegEx

javascript - 有没有更好的方法来重复链接的 jQuery 方法?

Javascript 中的 ASP.NET session

javascript - 删除无父 HTML 元素

javascript - 在特定元素上添加类而不影响其他元素

node.js - Mongo 和 Node.js 查找和聚合

regex - 用于 CSV 校正的 Perl REGEX 模式