根据数组中的数组更改div的内容

时间:2014-10-20 01:23:22

标签: javascript jquery html css arrays

index.html的Pastebin:http://pastebin.com/kdKFqTxe 只需复制并粘贴并运行它(这有效,但有一些破坏的img链接和没有css)。 关于pastebin,只需单击一个节点,然后单击视频下方的第一个损坏的图像。应该发生的是一个对话框应该出现与文章的链接(来自tubeArray)。所有相关代码都粘贴在下面。

我正在尝试在单击图像时动态更改div的内容。图像在第一个内部数组中有各自的id(内部数组中的第一个索引),还有另一个数组(索引3)。我希望在单击图像时使用JQuery将这些链接填充到我的div(id =“articleLinks”)。

JavaScript& JQuery的:

管阵列。 *注意:tubeArray中每个元素的第一个索引是ID&新闻文章与特定内容无关。只对tubeArray [0]& tubeArray [4]

 var tubeArray = [
            ['UQ', -27.495134, 153.013502, "http://www.youtube.com/embed/uZ2SWWDt8Wg",  
                [
                ["example.com", "Brisbane students protest university fee hikes"],
                ["example.com", "Angry protests over UQ student union election"],
                ]
            ],
            ['New York', 40.715520, -74.002036, "http://www.youtube.com/embed/JG0wmXyi-Mw",
                [
                ["example.com" , "NY taxpayers’ risky Wall Street bet: Why the comptroller race matters"]
                ]
            ],
            ['To The Skies', 47.09399, 15.40548, "http://www.youtube.com/embed/tfEjTgUmeWw", 
                [
                ["example.com","Battle for Kobane intensifies as Islamic State uses car bombs, Syrian fighters execute captives"],
                ["example.com","Jihadists take heavy losses in battle for Syria's Kobane"]
                ]
            ],
            ['Fallujah', 33.101509, 44.047308, "http://www.youtube.com/embed/V2EOMzZsTrE", 
                [
                ["example.com","Video captures family cat saving California boy from dog attack"],
                ["example.com","Fines of £20,000 for dogs that chase the postman"]
                ]
            ]
        ];

for循环遍历tubeArray中的每个元素,然后将 id 分配给第一个索引。还有一个调用函数 myFunctionId 的图像,它接受参数 this.id

for (i = 0; i < tubeArray.length; i++) {
    var id = tubeArray[i][0];

    //other code

    '<img src="img.png" onclick="myFunctionId(this.id);" id="' + id + '">' +

    //other code
}

function myFunctionId (id) {
        journal = id; 
        alert(journal) //just a test

        //I want to search through tubeArray with the id and find the matching inner array. 

        //I then want to loop through the innerArray and append to my html a link using JQuery.
        $('#articleLinks').append("<a href='"+innerArray[0]+"'>"+innerArray[1]+'</a>'); // use CSS to break lines
       }
}

HTML:

<div id="articleLinks">
    <a href="http:/www.google.com">Example Link</a><br>
</div>

非常感谢任何帮助。我试图简化&amp;我尽可能地删掉它,因此它是可读的。

1 个答案:

答案 0 :(得分:0)

试试这个......

function myFunctionId (id) { 
   console.log(tubeArray); 
   tubeArray.forEach(function(entry) {
       if (entry[0]==id) { 
         entry[4].forEach(function(innerArray){
            $('#articleLinks').append("<a href='"+innerArray[0]+"'>"+innerArray[1]+'</a>'); // use CSS to break lines
         });
         return;
       }
   });                 
}

它让我看起来像这样......你将不得不处理这个编码问题。与撇号。有很多方法可以处理它......

enter image description here

所以....如果是我......那不是。但如果是......我将使用关联数组而不是数字索引数组,因为它更容易阅读代码并了解您正在使用的内容以及在何处以及如何以及内容和内容。

tubeArray = {
    'UQ' :      { 'location': [-27.495134, 153.013502], 
                  'youtube':  "example.com/embed/uZ2SWWDt8Wg",  
                  'articles': [["example.com/queensland/brisbane-students-protest-university-fee-hikes-20140521-zrk8o.html", "Brisbane students protest university fee hikes"],
                               ["example.com/content/2012/s3578878.htm", "Angry protests over UQ student union election"], ]
                },
    'New York': { 'location': [0.715520, -74.002036], 
                  'youtube':  "example.com/embed/JG0wmXyi-Mw",
                  'articles': [["example.com/2014/10/19/ny-taxpayers-risky-wall-street-bet-why-the-comptroller-race-matters/" , "NY taxpayers’ risky Wall Street bet: Why the comptroller race matters"]],
                 },
     }