使用JQuery将JSON数据传递到DIV

时间:2013-10-15 08:07:41

标签: javascript jquery html css json

您好我有专家的以下建议,我正在尝试根据这些建议重建我的代码:

    来自$ .each()的
  • 你可以返回true或false。如果你返回false,那么 循环停止。
  • 尽量不要从连接字符串构建HTML。这很容易出现XSS 容易避免的漏洞。 jQuery为您提供了工具 安全地构建HTML。
  • 一般来说,出于同样的原因,尽量避免使用.html(), 特别是如果你已经有DOM元素可以使用了。
  • 不要使用像onclick这样的内联事件处理程序。完全没有。如初。

这是我正在制作的新代码:

var page = 1;
$(document).on('click', '#devotionclick', function blogs() {
    $('#postlist').empty();
   // $('#category').prepend('<div class="categories_listing"><span data-type="blogs" data-category="5">Blog Category</span></div>');
    var count = "5";
    var result = $.getJSON('http://howtodeployit.com/api/get_posts/?count=' + count + '&page=' + page, function (data, status) {
        if (data !== undefined && data.posts !== undefined) {
            $.each(data.posts, function (i, item) {    
                var str = item.title;

                $('#postlist').append('<div class="article"' + item.id + '"><div>' + item.title + '</div><div>' + item.excerpt + '</div></div>');
                if (data !== undefined) {
                    $('#stats').text('Page ' + data.query.page + ' of ' + data.pages + ' | Total posts ' + data.count_total + '');
                }
                if (data.query.page < data.pages) {
                    $("#loadmore").show();
                } else {
                    $("#loadmore").hide();
                }
            });
            page++;
        }
    });
    $('#postlist').append('<div id="loadmore"><div id="stats"></div><div id="loadmore">load more</div></div>');
    $('#loadmore').click(blogs);
});

HTML:

!-- Page: home -->
    <div id="home" data-role="page">
        <div class="ui_home_bg" data-role="content"></div>
        <div data-role="listview">
            <a href="#devotion" id="devotionclick" data-role="button">Daily Devotional Messages</a>
        </div><!-- links -->
    </div><!-- page -->

<!-- Page: Daily Devotional Messages -->
    <div id="devotion" data-role="page">
        <div data-role="header" data-position="fixed">
            <h2>Daily Devotional Messages</h2>
        </div><!-- header -->
        <div data-role="content" id="postlist"> </div><!-- content -->
    </div><!-- page -->

我现在遇到的问题是:

  1. 当我点击按钮时,它会加载前5个帖子,但当我点击“加载更多”文本时,它会加载下一个5而不是附加到现有列表。

  2. 列表不会显示为可点击的Listview项目

1 个答案:

答案 0 :(得分:1)

问题1 这是因为点击处理程序中的$('#postlist').empty(); ....您在加载新项目之前从页面中删除所有项目。删除此