jquery 查找类似autoComplete 实现模糊查询

 
以下内容是来自IT潮流网通过在文本框中输入查找文字,下面的左边选择框跟着动态变动,右边的文本狂则显示选中的信息,主要涉及到的方法有jquery的
filter ,toUpperCase,trim 。
filter 查找匹配字符 toUpperCase 转化为大写形式 trim 去除空格。结果见图
下面说下主要的思路:(keyup 监听键盘事件)
$().ready(function () {
        $("#searchLabel").keyup(
        function () {
            sl = $.trim($("#searchLabel").val());
            $("#lb div").hide();
            var $d = $("#lb div").filter(":contains('" + sl + "')");
            $d.show();
/* 以下是因为我的标签中有涉及到中文首个字母查找*/
            sl = sl.toUpperCase();
            $("#lb").find("div").each(function () {
                if (eval('/.*' + sl + '.*/').test($(this).attr("title"))) {
                    $(this).show();
                }
            });

        }
      )

eval('/.*' + sl + '.*/').test($(this).attr("title"))) 字符串匹配

双击事件:
  $("#labels").append("<div title='" + $(obj).attr("title") + "' οnclick='RemoveLabel(this," + id + ")'>" + $(obj).text() + "</div>");
双击移除事件:
  $(obj).remove();
    var ary = LabelNames.split(';');
    var ary2 = LabelIds.split(',');
    var nlname = "";
    var nlid = "";
    for (var i = 0; i < ary.length - 1; i++) {
        var str = ary[i];
        if (str != $(obj).text()) {
            nlname += str + ";";
        }
    }
    LabelNames = nlname;
    for (var i = 0; i < ary2.length - 1; i++) {
        var str = ary2[i];
        if (str != id) {
            nlid += str + ",";
        }
    }

双击事件和双击移除事件最主要的是要判断是否数据有重复,是否有移除掉相应的信息

1.jpg (22.74 KB, 下载次数: 0)

 

1.jpg

详见:http://www.itclw.net/thread-660-1-1.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值