使用JQuery Mobile和Json动态注入页面

时间:2013-02-28 03:00:11

标签: json jquery-mobile

感谢您查看我的问题。我是HTML,JQuery和JSon的新手。我正在尝试通过一些在线教程和www.lynda.com培训自学。我正在尝试制作一个动态显示页面上的术语列表的词汇表,当单击时会在标题中显示该术语,并在下面显示该定义。经过搜索和实验,我已经取得了进展,我已经从JSon对象填充了ul并链接到显示页面。但我不知道如何让显示页面正常工作。我认为答案就在这里:http://jquerymobile.com/demos/1.1.1/docs/pages/page-dynamic.html但我似乎无法将它拉下来,即使在Dreamweaver中也是如此。

这是JSFiddle:http://jsfiddle.net/LParker/PSntK/3/

HTML:

    <!-- Glossary -->
<div data-role="page" id="glossary">
<div data-role="header">
     <h3>
        Glossary
    </h3>
</div>
<ul data-role='listview' data-inset='true' id='resultsList'>
<!-- keep empty for dynamically added items -->
</ul>
</div>
    <!-- display -->
    <div data-role="page" id="display">
    <div data-role="header">
         <h3>
            Name Goes Here
        </h3>
    </div>
    <div data-role="content">
    <div>Definition goes here</div>
</div>

JavaScript的:

var jsonObject = {
"results": [{

    "term": "Term One",
        "definition": "This is the definition for Term Two",

},

{
    "term": "Term Two",
        "definition": "This is the definition of Term Two",

}, {
    "term": "Term Three",
        "definition": "This is the definition for Term Three",
}],
    "ok": "true"
}

var resultLength = jsonObject.results.length;
var listItems = [];



for (var i = 0; i < resultLength; i++) {
var term = jsonObject.results[i].term;


//Add result to array
listItems.push("<li><a href='#display'>" + term + " </a></li>");
}

//Append array to list and refresh
$('#resultsList').append(listItems.join(' '));
$('#resultsList').listview('refresh');

任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:5)

首先让我们先解决一些问题:

  1. 在json对象的每个definition成员之后删除额外的逗号。
  2. 将您的#resultsList列表视图放在<div data-role="content"></div>容器中。
  3. 提供从#display页面导航回#glossary页面的方法,例如在<a data-role="button" data-rel="back" data-icon="back">Back</a>页面的标题中添加标准jQM后退按钮#display
  4. 使用jQM时,您需要使用正确的event handlers
  5. 为简洁起见,我将变量jsonObject重命名为json

    您可以更简洁的方式填充列表视图:

    $.each(json.results, function(i, term){
        $('#resultsList').append('<li><a href="#display">' + term.term + '</a></li>')
    });
    $('#resultsList').listview('refresh');
    

    现在,在特定情况下,恕我直言,你不需要注入页面(虽然它当然可能),你只需更改#display事件pagebeforeshow页面中的内容。

    为此,由于您的json对象全局可用,您只需获取单击列表项的索引,将其传递到#display页面,使用它来访问json对象的结果数组以提取并显示术语和它的定义。 传递索引的最简单方法是使用您在click事件处理程序中设置的全局变量。

    var currentItem = 0;
    ...
    $('#resultsList li').click(function(){
        currentItem = $(this).index();
    });
    

    现在进入pagebeforeshow事件

    $('#display').on('pagebeforeshow', function(){
        $(this).find('[data-role=header] .ui-title').text(json.results[currentItem].term);
        $('#definition').html(json.results[currentItem].definition);
    });
    

    最后,此处正在为您工作 jsFiddle