2

我在我的主 ASP MVC 3 布局页面上收到了这个和其他一些奇怪的错误消息。

我正在使用以下脚本

<script src="@Url.Content("~/Scripts/modernizr-1.7.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery-1.8.3.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery-ui.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/typeahead.js")" type="text/javascript"></script>

并试图让typeahead.js在我们的导航栏中工作。以下是我目前在我的机器上的代码。我曾经在某个时间点进行过这项工作,但是在与同事同步后,预先输入的搜索不再起作用,我无法找到问题所在。

下面代码中的第一行给出了以下错误

Uncaught TypeError: Cannot read property 'Constructor' of undefined

但是,如果我注释掉该protoype.blur函数,则会收到此错误

Uncaught TypeError: Object [object Object] has no method 'typeahead' 

哪个指向$('.AgentSearch .typeahead).typeahead功能。被困在这几个小时,任何帮助将不胜感激。谢谢

        // Workaround for bug in mouse item selection
        $.fn.typeahead.Constructor.prototype.blur = function () {
            var that = this;
            setTimeout(function () { that.hide() }, 250);
        };

        $('.AgentSearch').typeahead({
            source: function (term, process) {
                var url = '@Url.Action("GetAgents", "Agent")';
                var agents = [];
                map = {};
                return ($.getJSON(url, { term: term }, function (data) {
                    $.each(data, function (i, item) {
                        map[item.Name] = item;
                        agents.push(item.Name);
                    });
                    process(agents);
                }));
            },
            highlighter: function (item) {
                var p = map[item];
                var display = ''
                             + "<div class='typeahead_wrapper'>"
                             + "<div class='typeahead_labels'>"
                             + "<div class='typeahead_primary'>" + p.Name + "</div>"
                             + "<div class='typeahead_third'><i>LastFour:</i> " + p.LastFour + "</div>"
                             + "</div>"
                             + "</div>";
                return display;
            },
            updater: function (item) {
                window.location.href = ("/Monet/Agent/Details/" + map[item].SymetraNumber);
            }
        });

这是我绑定到的搜索框

            <form class="navbar-search pull-left">   
                <input type="text" name="names" value="" id="AgentSearch" class="search-query" data-provide="typeahead" placeholder=" Agent Search"/> 
            </form>

编辑

这是浏览器呈现的脚本标签

<script src="/Scripts/modernizr-1.7.min.js" type="text/javascript"></script>
<script src="/Scripts/jquery-1.8.3.js" type="text/javascript"></script>
<script src="/Scripts/jquery-ui.js" type="text/javascript"></script>
<script src="/Scripts/typeahead.js" type="text/javascript"></script>
4

1 回答 1

0

看起来 typeahead 没有定义。

如果您尝试扩展 typeahead,这篇文章可能会有所帮助: 扩展 bootstrap-typeahead 以获取对象而不是字符串

$.fn 将始终返回一个对象('[]'),这就是为什么当您注释掉 .prototype.blur 时错误会发生变化,但它们都表示 'typeahead' 不存在。

只是一个猜测,但这可能是一个同步问题,您的代码在库加载之前运行。

于 2013-09-12T22:35:08.437 回答