选择中最接近的匹配项

Closest match in a select

本文关键字:最接近 选择      更新时间:2023-09-26

我有一个包含不同标题的select元素;例如:

<select name="titles">
  <option value="1">Mr.</option>
  <option value="2">Mrs.</option>
  <option value="3">Ms.</option>
  <option value="4">Dr.</option>
  [..]
</select>

然后我有一个字符串,其中包含一个用户提交的标题(最初写在一个自由形式的文本框中)。我的任务是在select中选择与该标题对应的option

然而,我突然想到,用户有时是愚蠢的。

我搜索的用户提供的字符串可能是"dr"或"dr"之类的。我需要将它与最相关的一个匹配(即"Dr."而不是"Mr.",两者都接近于说"Dr

我该怎么做?我只做过MySQL的LIKE和PHP的levenshtein()的近似匹配,据我所知,它们在JS中都不太相关。

jQuery 1.7.1可用。IE6兼容性与我无关。

提前谢谢!

如果我没有错的话,唯一合理(可接受)的变体是开头有大写字母/没有大写字母,结尾有一个缺失的点字符。

如果是这种情况,那么您可以简单地将用户字符串与select中的每个项目进行比较,并记住以上内容:

  • 将用户输入的第一个字符转换为大写
  • 如果用户字符串未以.结尾,则在字符串末尾添加.
  • 将修改后的用户字符串与select中的每个元素进行比较,看看其中一个是否匹配

用户从不愚蠢;)

在进行匹配之前,我会先在javascript中将所有字母转换为小写,然后查找点(.),然后可以将它们删除或添加到匹配字符串中(这是您的选择)。

希望能有所帮助。

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN"
   "http://www.w3.org/TR/html4/strict.dtd">
<html lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <script type="text/javascript" charset="utf-8" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
    <!-- Date: 2012-04-05 -->
    <script type="text/javascript" charset="utf-8">
    $(document).ready(function() {
        var title = "dr"
        $("#titles option").each(function(i, el) {
            var re = new RegExp(title, 'ig')
            if ($(el).html().match(re)) {
                $(el).attr("selected", "selected");
            }
        });
    })
    </script>
</head>
<body>
    <select name="titles" id="titles">
      <option value="1">Mr.</option>
      <option value="2">Mrs.</option>
      <option value="3">Ms.</option>
      <option value="4">Dr.</option>
    </select>
</body>
</html>

还有另一个解决问题的方法——给你的用户提供这个表单,这样他们就没有机会输入任何错误的数据。

您会考虑剥离将自由形式字符串与列表项匹配的额外层吗?可能有一个自动完成字段/下拉列表或类似功能;让用户输入并重新选择相同的数据两次似乎太过分了。

我本来打算建议研究一种模糊搜索算法,但拥有一个与特定标题匹配的值数组不是更简单吗?它可以与标准化周期、大写和空白区(即)进行比较

  • 用户输入的Drdr.Dr.将被标准化并与Dr.匹配
  • 用户输入的doctorDoctor将被规范化并匹配
  • 用户输入的docDoc.doc将被归一化和匹配等

这听起来像是一项令人麻木的任务,尽管要经历各种各样的迷雾等。真的首先要考虑将其变成一个标准化的下拉列表;唯一比这更难处理的是一个非规范化的地址字段:)