0

嗨,我正在尝试遍历一些 json 数据并将其输出到页面上,我的问题是它只显示 json 中的第一项,(波士顿庄园停车场)我无法让它显示第二项...

jsfiddle:http: //jsfiddle.net/35Jrc/6/

HTML:

<span class='showOnMap' 
     data-related='[
            {"id":"5","slug":"boston-manor-park-car-park","name":"Boston Manor Park car park","image":"","pinType":"ub","addr":"Boston Manor Road, London  ","lat":"51.48967509541307","lng":"-0.3164195004638941","contact":"Reel Film Locations: ","restrictions":"Shared use with park users. 6 classic 1960 Tower Blocks"},
            {"id":"4","slug":"gunnersbury-park-car-park","name":"Gunnersbury Park car park","image":"","pinType":"ub","addr":"Popes Lane, London  W3 8LQ","lat":"51.49963692687797","lng":"-0.29188622747801674","contact":"Reel Film Locations: 0845 402 2998","restrictions":"Shared use with sports ground users.  Weekends in season are busy with the public. 6 classic 1960 Tower Blocks"}
        ]'>
         click me
</span>
<div class="relatedHeader">Unit Bases near by:</div>
<div class="relatedDetails">

</div>

JS:

$('.showOnMap').click(function(){
    //alert('click');
    var myRelated = $(this).data('related');

    createRelated(myRelated)
    //addToPanel(panelData);
})     
function createRelated(myRelated){
        var relCount = 0;
        var rowCount = 0;
        var itemCount = 0;
            var relCount = 0;
        $.each(myRelated, function(k, v) {
            if(relCount == 3){
                relCount = 0;
            };
            // create a new row
            if(relCount == 0){
                var rowClass = 'relRow'+rowCount;
                //alert('new row class: .'+rowClass);
                $("<div></div>")
                .addClass("detailRow "+rowClass)
                .appendTo(".relatedDetails");
                rowCount++;
            }
            // create a new related item div
            var itemClass = 'item'+itemCount;
            //alert('new item class: .'+itemClass);
            $("<div></div>")
            .addClass("relatedItem "+itemClass)
            .appendTo('.'+rowClass);

            //$('.'+rowClass).append('.'+itemClass);
            // now loop through the keys and values and add the data
            //add the data to the related item
            $('.'+itemClass).data('location',this);
            //add item to to our row

            //$.each(obj, function(k, v) {
                  //tmp = {"id":"5","slug":"boston-manor-park-car-park","name":"Boston Manor Park car park","image":"","pinType":"ub","addr":"Boston Manor Road, London ","lat":"51.48967509541307","lng":"-0.3164195004638941","contact":"Reel Film Locations: ","restrictions":"Shared use with park users. External features unavaliable at present"};
                //if(k=='image'){
                    $('<img/>')
                    .addClass('relatedImage')
                    .attr("src", v.image)
                    .appendTo('.'+itemClass)
                //}
                //if(k=='name'){
                    $('<div></div>')
                    .addClass('relatedTitle')
                    .html(v.name)
                    .appendTo('.'+itemClass)
                //}
            //});
            itemCount++;
            relCount++;
        });
    };
4

1 回答 1

3

问题出在小提琴的第 32 行:

.appendTo('.'+rowClass);

检查循环rowClass的每次迭代中的等于$.each。它仅在满足此条件时第一次定义:

if(relCount == 0){
    var rowClass = 'relRow'+rowCount;
}

您应该更改存储添加项目的行的方式。(第 17 行和第 30 行的更改。)

$('.showOnMap').click(function(){
    var myRelated = $(this).data('related');

    createRelated(myRelated);
});


function createRelated(myRelated){

    // Clear any previous content
    $('.relatedDetails').html('');

    var relCount = 0;
    var rowCount = 0;
    var itemCount = 0;
    var relCount = 0;

    // Store a reference to the current row
    var row = '';

    console.log('myRelated', myRelated);
    $.each(myRelated, function(k, v) {
        console.log('k, v', k, v);
        console.log('relCount', relCount);
        if (relCount == 3) {
            relCount = 0;
        };
        // create a new row
        if(relCount == 0){
            rowClass = 'relRow'+rowCount;

            // Save the row you're creating
            row = $("<div></div>")
            .addClass("detailRow "+rowClass)
            .appendTo(".relatedDetails");
            rowCount++;
        }
        // create a new related item div
        var itemClass = 'item'+itemCount;
        //alert('new item class: .'+itemClass);
        var newItem = $("<div></div>")
        .addClass("relatedItem "+itemClass)
        .appendTo(row);

        //$('.'+rowClass).append('.'+itemClass);
        // now loop through the keys and values and add the data
        //add the data to the related item
        newItem.data('location',this);
        //add item to to our row



        //if(k=='image'){
        $('<img/>')
        .addClass('relatedImage')
        .attr("src", v.image)
        .appendTo('.'+itemClass)
        //}
        //if(k=='name'){
        $('<div></div>')
        .addClass('relatedTitle')
        .html(v.name)
        .appendTo('.'+itemClass)
        //}

        itemCount++;
        relCount++;
    });
};

你可以在这里看到它的作用:http: //jsfiddle.net/cYavP/1/

于 2013-03-14T20:09:50.120 回答