jquery.autocomplete.js 两种实现方法

<script type="text/javascript">
    var v = 1;
    var stockInfoJson = [
        { "name": "深发展A", "code": "000001", "spell": "sfza", "count":"32435" },
        { "name": "万科A", "code": "000002", "spell": "wka", "count":"231" },
        { "name": "ST 国 农", "code": "000004", "spell": "stgn", "count":"4567" },
        { "name": "世纪星源", "code": "000005", "spell": "sjxy", "count":"2345" },
        { "name": "深振业A", "code": "000006", "spell": "szya", "count":"8799" },
        { "name": "ST 达 声", "code": "000007", "spell": "stds", "count":"12345234" },
        { "name": "ST宝利来", "code": "000008", "spell": "stbll", "count":"56235" },
        { "name": "中国宝安", "code": "000009", "spell": "zgba", "count":"9833" },
        { "name": "S ST华新", "code": "000010", "spell": "ssthx", "count":"24878" },
        { "name": "山航B", "code": "200152", "spell": "shb", "count":"32435" },
        { "name": "*ST帝贤B", "code": "200160", "spell": "stdxb", "count":"32435" },
        { "name": "雷伊B", "code": "200168", "spell": "lyb", "count":"32435" },
        { "name": "宝石B", "code": "200413", "spell": "bsb", "count":"32435" },
        { "name": "小天鹅B", "code": "200418", "spell": "xteb", "count":"32435" },
        { "name": "粤高速B", "code": "200429", "spell": "agsb", "count":"32435" },
        { "name": "宁通信B", "code": "200468", "spell": "ltxb", "count":"32435" },
        { "name": "晨鸣B", "code": "200488", "spell": "cmb", "count":"32435" },
        { "name": "珠江B", "code": "200505", "spell": "zjb", "count":"32435" },
        { "name": "闽灿坤B", "code": "200512", "spell": "mskb", "count":"32435" },
        { "name": "华电国际", "code": "600027", "spell": "hdgj", "count":"32435" }
    ];

        $(function () {
            /*
            $.ajax({
            type: "POST",
            contentType: "application/json",
            url: "AjaxPage.aspx/GetAllHints",
            data: "{}",
            dataType: "json",
            success: function (msg) {
            var datas = eval('(' + msg.d + ')');
            $("#keywords").autocomplete(
            datas,
            {
            minChars: 1,
            matchCase: false, //不区分大小写
            autoFill: false,
            max: 10,
            formatItem: function (row, i, max) {
            return "<table width='100%' border='0' cellspacing='0' cellpadding='0'><tr><td align='left' height='24'><b>" + row.name + "</b></td><td align='right'><font style='color: #009933; font-family: 黑体; font-style: italic'>约" + row.count + "个宝贝</font>&nbsp;&nbsp;</td></tr></table>";
            },
            formatMatch: function (row, i, max) {
            return row.name;
            },
            formatResult: function (row) {
            return row.name;
            },
            reasultSearch: function (row, v)//本场数据自定义查询语法 注意这是我自己新加的事件
            {
            //自定义在code或spell中匹配
            if (row.data.code.indexOf(v) == 0 || row.data.spell.indexOf(v) == 0 || row.data.name.indexOf(v) == 0) {
            return row;
            }
            else {
            return false;
            }
            }
            }).result(function (event, data, formatted) {
            var encodeKeyword = encodeURIComponent(encodeURIComponent(data.name));
            searchParams = "keyword=" + encodeKeyword;
            window.location.href = "http://localhost/products.aspx?" + searchParams;
            });
            }
            });
            */

            $("#keywords").autocomplete(
                "SearchHanle.ashx",
                {
                    minChars: 1,
                    matchCase: false, //不区分大小写
                    autoFill: false,
                    max: 10,
                    parse: function (data) {
                        var d = eval("(" + data + ")"); //此处要用eval函数;
                        var rows = new Array();
                        for (var i = 0; i < d.length; i++) {
                            rows[rows.length] = {
                                data: d[i],
                                value: d[i].code,
                                result: d[i].name
                            }
                        }
                        return rows;
                    },
                    formatItem: function (row, i, max) {
                        return "<table width='100%' border='0' cellspacing='0' cellpadding='0'><tr><td align='left' height='24'><b>" + row.name + "</b></td><td align='right'><font style='color: #009933; font-family: 黑体; font-style: italic'>约" + row.count + "个宝贝</font>&nbsp;&nbsp;</td></tr></table>";
                    },
                    formatMatch: function (row, i, max) {
                        return row.name;
                    },
                    formatResult: function (row) {
                        return row.name;
                    },
                    reasultSearch: function (row, v)//本场数据自定义查询语法 注意这是我自己新加的事件
                    {
                        //自定义在code或spell中匹配
                        if (row.data.code.indexOf(v) == 0 || row.data.spell.indexOf(v) == 0 || row.data.name.indexOf(v) == 0) {
                            return row;
                        }
                        else {
                            return false;
                        }
                    }
                }).result(function (event, data, formatted) {
                    var encodeKeyword = encodeURIComponent(encodeURIComponent(data.name));
                    searchParams = "keyword=" + encodeKeyword;
                    window.location.href = "http://localhost/products.aspx?" + searchParams;
                });
        });
</script>

先记一下,方法二是存在bug的。

posted on 2015-08-03 14:36  静以修身俭以养德  阅读(1472)  评论(0编辑  收藏  举报

导航