感谢您查看我的问题。我是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');
任何帮助将不胜感激!
答案 0 :(得分:5)
首先让我们先解决一些问题:
definition
成员之后删除额外的逗号。#resultsList
列表视图放在<div data-role="content"></div>
容器中。#display
页面导航回#glossary
页面的方法,例如在<a data-role="button" data-rel="back" data-icon="back">Back</a>
页面的标题中添加标准jQM后退按钮#display
。 为简洁起见,我将变量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 。