2

并感谢您查看我的问题。我是 HTML、JQuery 和 JSON 的新手。我正在尝试通过一些在线教程和 www.lynda.com 培训自学。我正在尝试制作一个词汇表,在页面上动态显示术语列表,单击时会在标题中显示术语及其下方的定义。经过搜索和实验,我取得了进展,我的 ul 从 JSon 对象填充并链接到显示页面。但我不知道如何让显示页面正常工作。我认为答案在这里: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');

任何帮助,将不胜感激!

4

1 回答 1

5

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

  1. definition在 json 对象的每个成员之后去掉额外的逗号。
  2. 将您的#resultsList列表视图放入<div data-role="content"></div>容器中。
  3. 提供从#display页面导航到页面的方法,例如通过在页面标题中#glossary添加标准 jQM 后退按钮。<a data-role="button" data-rel="back" data-icon="back">Back</a>#display
  4. 在使用 jQM 时,您需要使用适当的事件处理程序

为简洁起见,我将您的变量重命名jsonObjectjson.

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

$.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

于 2013-02-28T07:30:16.743 回答