- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在通过 getJSON 加载一个充满项目的 ListView 。
但是当我点击 ListView 项目时,我想到达该项目的“详细信息”页面。
现在,例如在 ASP.NET 中,您可以执行 Details.aspx?Id=1,但是在 jQuery Mobile 中我该怎么做?当我通过 getJSON 方法获取对象时。我需要将它们存储在数组或其他东西中吗?
我应该补充一点,在我当前的 getJSON 响应中,没有一个对象具有与其关联的 ID。但这只是一个沙箱,我只是在玩 jQuery Mobile 并从 Flickr 获取我的提要:
$(function() {
$.mobile.showPageLoadingMsg("Laddar...");
$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?jsoncallback=?",
{
tags: "cat",
tagmode: "any",
format: "json"
},
function(data) {
$.each(data.items, function(i,item){
$('#list')
.append('<li><a><img src="images/de.png" class="ui-li-icon">' + item.author + '</a></li>')
.listview('refresh');
});
$.mobile.hidePageLoadingMsg();
});
});
在 jQuery Mobile 中设置“详细信息页面”的做法是什么?我是否应该在上面的代码中使用 id=x 创建 ,然后以某种方式在数组中的该索引处获取一个对象(我尚未创建)?
最佳答案
首先,您可以采取一些措施来大大提高代码的性能:
$(function() {
var photos = {};
$.mobile.showPageLoadingMsg("Laddar...");
$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?jsoncallback=?",
{
tags: "cat",
tagmode: "any",
format: "json"
},
function(data) {
//store photo data for later
photos = data;
//setup an array (or string) to buffer the output
var output = [];
for (var i = 0, len = data.items.length; i < len; i++) {
//add this index to the output array
output.push('<li><a data-index="' + i + '" href="#"><img src="images/de.png" class="ui-li-icon">' + data.items[i].author + '</a></li>');
}
//here I am selecting the list element only once and only refreshing it once
$('#list').append(output.join('')).listview('refresh');
$.mobile.hidePageLoadingMsg();
});
});
现在,您可以将 click
事件处理程序添加到 #list
ListView 中的链接,并为 jQuery Mobile 创建必要的伪页面:
$('#list').delegate('a', 'click', function (event) {
//get the index of this page/link and cache some objects
var $this = $(this),
index = $this.attr('data-index'),
$toPage = $('#details_' + index);
//stop the browser from scrolling to the top of the page due to the hash mark (#) in the link's href attribute
event.preventDefault();
//check to see if the page for the link clicked already exists, if so then don't re-add it to the DOM
if ($toPage.length === 0) {
//no page was found so create one, we can access the photos object to insert data related to the link clicked
$('body').append('<div data-role="page" id="details_' + index + '"><div data-role="content"><p>Some Key: ' + photos.items[index].some_key + '</p><a data-role="button" href="#home">Back Home</a></div></div>');
//set the $toPage variable to the newly added page so jQuery Mobile can navigate to it
$toPage = $('#details_' + index);
}
//change to the desired page
$.mobile.changePage($toPage);
});
这是一个演示:http://jsfiddle.net/m4Yt8/
我不确定您的 JSON 是什么样子,因此我无法确定如何将 JSON 对象中的数据添加到新页面中,但是上面的模板应该非常接近。
关于jQuery Mobile - 带有自定义对象的详细信息页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8699054/
$.mobile.pageContainer 是指包含其他虚拟页面的元素。它设置为 .所以我认为它可以改变。实际上,某些 JQM 方法 (changePage) 允许您为页面指定非默认页面容器。 J
如何在移动设备上更改方向时触发事件。 调整大小 在 iPod Touch 上运行良好,但在使用 Opera mobile 作为浏览器的移动设备上运行良好。 有关如何在 Opera mobile 上触发
我想为我拥有的装有 Windows Mobile 2003 的设备开发一些应用程序,但我不想为此寻找 Visual Studio 2003 的副本。我想知道是否可以将 Mobile 6 SDK 用于此
我试图阻止 jQuery Mobile 在调用 changePage 时隐藏加载微调器。 程序流程是这样的,从点击一个链接开始,它的点击事件定义如下: $('body').delegate('.lib
我想为运行 Windows Mobile 5 的扫描仪开发应用程序。 MSDN 站点说要下载最新的 SDK(Windows Mobile 6 Professional SDK)。这会起作用还是我应该下
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我正在尝试使用 Jquery mobile 创建弹出菜单,通过单击按钮,它应该在不更改页面的情况下弹出菜单选项,类似于 jquery mobile 的选择菜单。在 JQM 中有没有办法做到这一点? 谢
在移动设备中,当我打开我的页面并选择一个输入框时,虚拟键盘打开,页面自动滚动以将输入框置于中心。 我不想要这个 Action 。 我搜索了很多答案,其中大多数建议在调整大小事件中手动调用以下 java
jQuery 移动列表中是否可以有多个拆分按钮? 我试过这样做: 1 但它不起作用。将链接包装在 中也不行.我做错了什么,
我想从我的 .js 文件中打开 .html 文件。所以我使用了 $.mobile.changePage("file.html")。在file.html 中有file.js。但是 file.js 在调用
我们有许多使用 Windows Mobile 6 的用户,需要应用较小的更改。例如。更新注册表设置。一种选择是使用我们的设备管理软件推送和执行可执行文件。 我希望这对熟悉 VBScript/JScri
我在PHP网站上有一个日期字段,并且我正在使用jQuery Mobile作为移动网站。 在移动浏览器(例如android上的firefox mobile)上浏览网站时,单击日期文本输入时,会出现日历对
我正在构建一个PhoneGap + JQuery Mobile应用程序,但似乎无法阻止它通过双击放大。我按照http://www.tricedesigns.com/2012/01/17/mobile-
随着 jQuery Mobile 1.3 的到来,.navigate()已添加功能。我听说这是更改页面的推荐方法,似乎他们解决了在页面之间传输数据的问题。 问题是,既然已经简化了,我该如何访问 cha
我想得到一个 input文本区域和 submit按钮附在它的右侧。 理想情况下,两者将使用 100% 的宽度并且并排放置。 我一直在尝试玩弄ui-grid-a和类似的选择,但一切都失败了。你可以看到一
我正在使用 jquery-mobile,我有这两个按钮: Pro: Reset 我希望它们并排显示(内联)。但我想不通。我做了this但它不起作用。你能帮我吗 ?这是我的 CSS:
我正在为 Windows Mobile 6.5 (Samsung Omnia II i8000) 开发 native 应用程序。进行一些更改后,我的应用程序在运行时挂起。 问题是我的应用程序也在启动期
有没有办法从周围和图标中删除背景光盘(圆圈)?我找到的光盘的唯一引用如下 background: rgba(0,0,0,.4) /*{global-ic
jQuery 移动版虽然在很多方面都很棒,但有时也令人沮丧。在这种情况下,我试图动态创建库中非常好的按钮之一。 基本上我想要做的是在输入字段中输入文本,当按下空格键时,它会创建一个带有文本的 jQue
我想在我的第 2 页上显示标题。使用以下内容是否有效: "> .... ? 最佳答案 这取决于你定义什么为“有效”
我是一名优秀的程序员,十分优秀!