1

我正在使用来自该站点/脚本的 jQuery 链接选择下拉框。我把它放在侧边栏中,它在主页上工作正常,但在帖子页面上不起作用,调试器指出了这个错误。

Uncaught TypeError: Object function ()
{for(var a=[];this.length;)a.push(this.splice(Math.random()*this.length,1));
for(;a.length;)this.push(a.pop());return this} has no method 'replace'

它说有一个错误escapeQuotes : function(str) {return str.replace(/([""\\])/g, "\\$1");

脚本的开头:

(function($) {
  $.dynamicDropdown = {
    /**
     * Escape quotation marks and slashes
     * @param {String} String to format
     * @return {String}
     */
    escapeQuotes : function(str) {
      return str.replace(/([""\\])/g, "\\$1");
    },

这是我调用该函数的方式。我正在使用 json 文件将选项文本和值拉入选定的框中:

$(document).ready(function(){

    $.getJSON('suggest.json', function(data){

        var $select = $('#mySelectID');

        $.each(data, function (index, o) {
            var $option = $("<option/>").attr("value", o.Box1ID + ":" + o.Box3).text(o.Box1 + "|" + o.Box2 + "|" + o.Box3);
            $select.append($option);
        });

        $("#mySelectID").dynamicDropdown({"delimiter":"|"});

    });
});

编辑:

似乎与我刚刚放在网站上的随机图像旋转器有冲突。我暂时移除了旋转器,链式选择框工作正常。这是一个显示错误的示例。这是没有随机旋转器的

Array.prototype.shuffle = function() {
                var s = [];
                while (this.length) s.push(this.splice(Math.random() * this.length, 1));
                while (s.length) this.push(s.pop());
                return this;
            }

            var picData = [
                ['img1','url_1'],
                ['img2','url_2'],
                ['img3','url_3'],

            picO = new Array();
            randIndex = new Array();  //array of random indexes
            for(i=0; i < picData.length; i++){
                picO[i] = new Image();
                picO[i].src = picData[i][0];
                picO[i].alt = picData[i][1];
                randIndex.push(i);
            }
            randIndex.shuffle();
            window.onload=function(){
                var mainImgs = document.getElementById('carouselh').getElementsByTagName('img');


                for(i=0; i < mainImgs.length; i++){
                    mainImgs[i].src = picO[randIndex[i]].src; //assign a random image
                    mainImgs[i].parentNode.href = picData[randIndex[i]][1];
                    mainImgs[i].alt = picData[randIndex[i]][1];
                }

            }
4

1 回答 1

5

在您使用的这个脚本中,问题很可能出现在这些代码行中:

for (var i in parts) {
      name += "[\"" + $.dynamicDropdown.escapeQuotes(parts[i]) + "\"]";
  ...
}

关键是,不要使用for in循环遍历数组,因为可能添加了一个函数,Array.prototype它显示在for in数组的循环中,只需将其更改为:

for (var i=0;i<parts.length;i++) {
      name += "[\"" + $.dynamicDropdown.escapeQuotes(parts[i]) + "\"]";
  ...
}

那么这将不再具有该功能。


正如您在帖子中添加的那样,原因正是我所指出的。但是如果你仍然坚持使用for in循环,你应该检查这样的类型parts[i]

for (var i in parts) {
      if(typeof parts[i] != "string") continue;
      name += "[\"" + $.dynamicDropdown.escapeQuotes(parts[i]) + "\"]";
  ...
}

for in你对另一个循环有同样的问题:

for (var i in options) {
    option = $(document.createElement("option"))
      .val($.isArray(options[i]) ? i : options[i])
      .html(i)
      .appendTo(select);
}

将其更改为for (var i=0;i<options.length;i++)或添加:

if(typeof options[i] != "string") continue;

到你的 for 循环的第一行。

于 2014-02-22T19:56:59.067 回答