jquery自动完成工作与旧版本的浏览器,但不是新的

jquery Autocomplete working with older versions of the browsers but not new ones?

本文关键字:浏览器 版本 工作 jquery      更新时间:2023-09-26

这是我的自动完成的JSON数据

{ "list" : [ {
    "genericIndicatorId" : 100,
    "isActive" : false,
    "maxValue" : null,
    "minValue" : null,
    "modificationDate" : 1283904000000,
    "monotone" : 1,
    "name":"Abbau",
    "old_name" : "abbau_change_delete_imac",
    "position" : 2,
    "systemGraphics" : "000000",
    "unitId" : 1,
    "valueType" : 1,
    "description" : "Abbau",
    "weight" : 1
}]}

我写的代码是

$("#<portlet:namespace />giName").autocomplete({
            source :`enter code here` function( request, response ) {
                $.post(
                    "<%=AJAXgetGIs%>",
                    {
                        "<%=Constants.INDICATOR_NAME%>" : request.term,
                        "<%=Constants.SERVICE_ID%>" : <%=serviceId%>
                    },
                    function( data ) {
                        response( $.map( data.list, function( item ) {
                                //alert(item.name + " || " + item.genericIndicatorId);
                                item.value = item.name;
                            return item;
                        }));
                    },
                    "json"
                );
            },
            minLength : 2

我使用jquery-ui-1.8.14.autocomplete.min.js插件自动完成我得到的问题是,它没有在新浏览器中显示所有匹配的结果。例如,如果i输入"an",其中should与"anzahl"关键字匹配,则firebug显示类似"字符串中错误的控制字符字面量"的错误。结果显示了字母"as,sa...."。任何帮助将不胜感激谢谢你

错误消息意味着您的JSON响应中有控制字符(例如'n, 't等)。根据ECMA262 5ed, JSON字符串中不允许使用换行符和其他控制字符。您可以通过转义或删除这些字符来很容易地修复它,无论是从PHP还是从Javascript。

在这里你可以找到一个如何从PHP修复它的例子,因为问题很可能来自json_encode(我假设你正在使用):http://codepad.org/Qu7uPt0E如您所见,json_encode不会转义'n,因此您必须在输出之前手动进行转义。

现在是关于旧浏览器的秘密。如果你看一下jQuery的parseJSON函数,你会注意到它首先尝试用浏览器内置的JSON对象解析字符串,如果没有找到,它就会执行(某种程度上的)eval(即使使用换行符也能工作)。所以它可能适用于你的Firefox <3.5或IE <它们没有原生JSON对象。此外,它可能与其他搜索词(如as等)一起工作,因为它们不包括具有控制字符的结果。>

添加到绘图者的正确答案

查看下载JSON2库https://github.com/douglascrockford/JSON-js这就是我解决这个问题的方法