- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jQuery
框架-jcarousel.js
在我的移动应用程序的页面上水平订购一些项目 jQuery Mobile
+ HTML
.
当我导航到页面时,首先我从网络服务获取所有图像,将它们放在垂直列表中 - <ul>
动态使用JavaScript
,并以这种方式从索引调用脚本:
$('#imagesPage').live('pageshow', function (event, ui) {
jQuery('#imagesList').jcarousel({visible:2});
});
它在某些移动设备上运行良好,但在 iPhone 中,例如,在导航到该页面时,它 缓慢完成,因此您首先会看到垂直列表,1-2 秒后它会变为水平列表。
我该如何改进它,这样我就不会看到从垂直到水平的几秒钟的延迟变化,并且仅在列表正确组织后才显示页面。
最佳答案
那你就应该作弊。
<强> jCarousel 有一个init回调函数。让您的 ul
容器用一点 css
隐藏:
display: block;
当 jCarousel 完成初始化,只是通过init
回调函数显示ul
容器。
工作 HTML:
<!DOCTYPE html>
<html>
<head>
<title>jQM Complex Demo</title>
<meta http-equiv='Content-Type' content='text/html; charset=utf-8'/>
<meta name="viewport" content="width=device-width; initial-scale=1.0; maximum-scale=1.0; minimum-scale=1.0; user-scalable=no; target-densityDpi=device-dpi"/>
<link rel="stylesheet" href="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.css" />
<link rel="stylesheet" href="http://sorgalla.com/projects/jcarousel/skins/tango/skin.css" />
<style>
.hidden {
display: none;
}
</style>
<script src="http://sorgalla.com/projects/jcarousel/lib/jquery-1.9.1.min.js"></script>
<script src="http://sorgalla.com/projects/jcarousel/lib/jquery.jcarousel.min.js"></script>
<script src="http://code.jquery.com/mobile/1.3.1/jquery.mobile-1.3.1.min.js"></script>
<script>
$(document).on('pagebeforeshow', '#index', function(){
$('#mycarousel').jcarousel({
scroll: 1,
initCallback: carouselInit
});
});
function carouselInit() {
$('#mycarousel').show();
}
</script>
</head>
<body>
<div data-role="page" id="index">
<div data-theme="b" data-role="header">
<h1>Index page</h1>
</div>
<div data-role="content">
<ul id="mycarousel" class="jcarousel-skin-tango hidden">
<li><img src="http://static.flickr.com/66/199481236_dc98b5abb3_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/75/199481072_b4a0d09597_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/57/199481087_33ae73a8de_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/77/199481108_4359e6b971_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/58/199481143_3c148d9dd3_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/72/199481203_ad4cdcf109_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/58/199481218_264ce20da0_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/69/199481255_fdfe885f87_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/60/199480111_87d4cb3e38_s.jpg" width="75" height="75" alt=""/></li>
<li><img src="http://static.flickr.com/70/229228324_08223b70fa_s.jpg" width="75" height="75" alt=""/></li>
</ul>
</div>
</div>
</body>
</html>
关于javascript - 在移动设备上的 pageshow() 事件上使用 jcarousel 框架时延迟几秒,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16580984/
我正在制作一个 JQuery Mobile Web 应用程序,并且遇到了一个有趣的问题。我正在尝试从 pageshow 函数中动态注入(inject)页面的内容。我知道正在调用 pageshow 函数
在我的 jQuery 移动应用程序中,需要在调用 pageshow 事件时插入 DOM,我尝试了一整天但没有成功。 首先在document.ready中插入一些字段,之后需要在pageshow事件触发
我在 jquery pageshow 函数中有一个函数,只有在某个页面 (id) 上时才应该被激活。但出于某种原因,它不运行该脚本。这些页面是带有 id 的动态页面。 这是我的代码示例 $(docum
我遇到了 pageshow/pagehide 事件,但我不太确定它们是如何工作的。 我在 document 上注册了它们,后来在 window 对象上注册了它们,但它们从未触发。 我原以为它们会在为
我遇到以下情况,在第一次进入页面或从另一个页面返回该页面时,我需要运行一些“代码”。 Safari 的缓存功能 ( https://webkit.org/blog/516/webkit-page-ca
我使用 jQuery Mobile 1.2 创建了一个简单的 Web 应用程序。该应用程序由主页index.html 和名为settings.html 的第二页组成。主页的标题部分包含一个用于打开设置
我有两个页面,test1.html 和 test2.html。每当其中一个页面可见时,我都想执行一些代码。 这是两个页面: test1.html: test1
我有一个 jquery 移动网络应用程序,我想用一些信息填充 pageshow 上的 div 列表。 $('#data').live('pageshow', function (event, ui)
我有以下简单的 JavaScript,我需要它来在页面重新加载时重新初始化一些变量,特别是当页面从 Safari BFCache 提供时: jQuery(window).bind('pageshow'
我是 jquery 移动框架工作的新手。根据我的观察,我无法在我的文档的第一页上触发 pagebeforeshow 事件 有人遇到过同样的问题吗?请建议我触发事件的步骤或任何其他选择 最佳答案 演示
我正在编写一个 Firefox 插件并在数组中跟踪每个页面的工作人员。除了管理此阵列所需的一些花哨的步法(如此处所述 https://bugzilla.mozilla.org/show_bug.cgi
我的网页有问题。我认为这是这样的问题:https://stackoverflow.com/questions/24350594/jqm-pageshow-event-firing-number-of-
我有以下代码: $( function() { window.onload = function () { alert
我有一个每当显示页面时都需要调用的函数,无论是通过标准页面加载还是通过 jQuery Mobile 的 AJAX 导航机制。目前,我的代码工作没有问题,但我觉得有一种更优雅的方法。 在我的页面的页脚中
我有一个 JQuery Mobile 应用程序。在应用程序的第一页上,我尝试在加载时设置一些字段值(如果之前已设置)。为了尝试做到这一点,我目前有以下内容: 索引.html
我正在使用 jQuery框架-jcarousel.js在我的移动应用程序的页面上水平订购一些项目 jQuery Mobile + HTML . 当我导航到页面时,首先我从网络服务获取所有图像,将它们放
我有一个多页 HTML。第一页上有一个指向搜索页面的链接,我想在其中自动将搜索栏的文本框聚焦。 在我当前的代码中,某些动画似乎滞后于 pageshow 事件,从技术上讲,直到事件触发后才会出现。 我在
HTML5 有一个 pageshow event .在什么情况下,它的工作方式与主体的 onload 处理程序不同? 最佳答案 每次加载页面时都会触发 pageshow 事件,而当从缓存中加载页面时,
我们如何为 pageShow and pageHide 进行 JavaScript 对象检测?处理程序? if( /* pagehide is supported */ ){ window.ad
我对 pageinit 的用法有点困惑和 pageshow jQuery Mobile 中的方法。我知道pageinit在初始化和 pageshow 期间调用每次渲染页面时都会调用。 我有一个使用 $
我是一名优秀的程序员,十分优秀!