元素上触发 tap 事件时,隐藏当前
元素:
实例
$("p").on("tap",function(){
$(this).hide();
});
亲自试一试
jQuery Mobile Taphold
taphold 事件在用户敲击某个元素并保持一秒时被触发:
实例
$("p").on("taphold",function(){
$(this).hide();
});
亲自试一试
jQuery Mobile Swipe
swipe 事件在用户在某个元素上水平滑动超过 30px 时被触发:
实例
$("p").on("swipe",function(){
$("span").text("Swipe detected!");
});
亲自试一试
jQuery Mobile Swipeleft
swipeleft 事件在用户在某个元素上从左滑动超过 30px 时被触发:
实例
$("p").on("swipeleft",function(){
alert("You swiped left!");
});
亲自试一试
jQuery Mobile Swiperight
swiperight 事件在用户在某个元素上从右滑动超过 30px 时被触发:
实例
$("p").on("swiperight",function(){
alert("You swiped right!");
});
亲自试一试
jQuery Mobile 滚动事件
jQuery Mobile 触控
jQuery Mobile 方向
jQuery Mobile 提供两种滚动事件:在滚动开始和当滚动结束。
jQuery Mobile Scrollstart
scrollstart 事件在用户开始滚动页面时被触发:
实例
$(document).on("scrollstart",function(){
alert("开始滚动!");
});
亲自试一试
注释:iOS 设备会在滚动事件发生时冻结 DOM 操作,这意味着当用户滚动时无法改变任何事物。不过 jQuery 团队正致力于解决该问题。
jQuery Mobile Scrollstop
scrollstop 事件在用户停止滚动页面时被触发:
实例
$(document).on("scrollstop",function(){
alert("结束滚动!");
});
亲自试一试
jQuery Mobile 方向事件
jQuery Mobile 滚动
jQuery Mobile 页面事件
jQuery Mobile orientationchange 事件
orientationchange 事件在用户垂直或水平旋转移动设备时被触发。
Mobile
Mobile
如需使用 orientationchange 事件,请把它添加到 window 对象:
$(window).on("orientationchange",function(){
alert("方向已改变!");
});
callback 函数可以设置一个参数,即 event 对象,它会返回移动设备的方向:"portrait" (设备被握持的方向是垂直的)或 "landscape" (设备被握持的方向是水平的):
实例
$(window).on("orientationchange",function(event){
alert("方向是:" + event.orientation);
});
亲自试一试
由于 orientationchange 事件与 window 对象绑定,我们能够使用 window.orientation 属性来,例如,设置不同样式以区分 portrait 和 landscape 视图:
实例
$(window).on("orientationchange",function(){
if(window.orientation == 0) // Portrait
{
$("p").css({"background-color":"yellow","font-size":"300%"});
}
else // Landscape
{
$("p").css({"background-color":"pink","font-size":"200%"});
}
});
亲自试一试
提示:window.orientation 属性对 portrait 视图返回 0,对 landscape 视图返回 90 或 -90。
jQuery Mobile 页面事件
jQuery Mobile 方向
jQuery Mobile 实例
jQuery Mobile 页面事件
在 jQuery Mobile 中与页面打交道的事件被分为四类:
Page Initialization - 在页面创建前,当页面创建时,以及在页面初始化之后
Page Load/Unload - 当外部页面加载时、卸载时或遭遇失败时
Page Transition - 在页面过渡之前和之后
Page Change - 当页面被更改,或遭遇失败时
如需关于所有 jQuery Mobile 事件的完整信息,请访问我们的 jQuery Mobile 事件参考手册。
jQuery Mobile Initialization 事件
当 jQuery Mobile 中的一张典型页面进行初始化时,它会经历三个阶段:
在页面创建前
页面创建
页面初始化
每个阶段触发的事件都可用于插入或操作代码。
事件 描述
pagebeforecreate 当页面即将初始化,并且在 jQuery Mobile 已开始增强页面之前,触发该事件。
pagecreate 当页面已创建,但增强完成之前,触发该事件。
pageinit 当页面已初始化,并且在 jQuery Mobile 已完成页面增强之后,触发该事件。
下面的例子演示在 jQuery Mobile 中创建页面时,何时触发每种事件:
实例
$(document).on("pagebeforecreate",function(event){
alert("触发 pagebeforecreate 事件!");
});
$(document).on("pagecreate",function(event){
alert("触发 pagecreate 事件!");
});
$(document).on("pageinit",function(event){
alert("触发 pageinit 事件!")
});
亲自试一试
jQuery Mobile Load 事件
页面加载事件属于外部页面。
无论外部页面何时载入 DOM,将触发两个事件。第一个是 pagebeforeload,第二个是 pageload (成功)或 pageloadfailed(失败)。
下表中解释了这些事件:
事件 描述
pagebeforeload 在任何页面加载请求作出之前触发。
pageload 在页面已成功加载并插入 DOM 后触发。
pageloadfailed 如果页面加载请求失败,则触发该事件。默认地,将显示 "Error Loading Page" 消息。
下列演示 pageload 和 pagloadfailed 事件的工作原理:
实例
$(document).on("pageload",function(event,data){
alert("触发 pageload 事件!\nURL: " + data.url);
});
$(document).on("pageloadfailed",function(event,data){
alert("抱歉,被请求页面不存在。");
});
亲自试一试
jQuery Mobile 过渡事件
我们还可以在从一页过渡到下一页时使用事件。
页面过渡涉及两个页面:一张“来”的页面和一张“去”的页面 - 这些过渡使当前活动页面(“来的”页面)到新页面(“去的”页面的改变过程变得更加动感。
事件 描述
pagebeforeshow 在“去的”页面触发,在过渡动画开始前。
pageshow 在“去的”页面触发,在过渡动画完成后。
pagebeforehide 在“来的”页面触发,在过渡动画开始前。
pagehide 在“来的”页面触发,在过渡动画完成后。
下列演示了过渡时间的工作原理:
实例
$(document).on("pagebeforeshow","#pagetwo",function(){ // 当进入页面二时
alert("页面二即将显示");
});
$(document).on("pageshow","#pagetwo",function(){ // 当进入页面二时
alert("现在显示页面二");
});
$(document).on("pagebeforehide","#pagetwo",function(){ // 当离开页面二时
alert("页面二即将隐藏");
});
$(document).on("pagehide","#pagetwo",function(){ // 当离开页面二时
alert("现在隐藏页面二");
});
亲自试一试
jQuery Mobile 实例
jQuery Mobile 页面事件
jQuery Mobile Data
jQuery Mobile 页面
基础的移动网页
多页面
对话框
例子解释
jQuery Mobile 过渡
淡入淡出效果
翻页效果
流效果
弹窗效果
滑动效果
滑动淡出效果
上滑动效果
下滑动效果
翻页效果
无过渡效果
逆转效果
例子解释
jQuery Mobile 按钮
创建按钮
行内按钮
分组按钮
后退按钮
带有和不带有圆角的按钮
小型和常规尺寸的按钮
带有和不带有阴影的按钮
例子解释
jQuery Mobile 按钮图标
向按钮添加图标
定位图标
只显示图标
例子解释
jQuery Mobile 工具栏
创建页眉和页脚
在页眉中添加按钮
在页眉中向左侧添加按钮
在页眉中向右侧添加按钮
带有按钮的页脚
带有居中对齐按钮的页脚
带有分组按钮的页脚
带有水平分组按钮的页脚
行内定位 - 页眉和页脚与页面内容行内定位
固定定位 - 页眉和页脚将保留在页面的顶部和底部
全屏定位 - 页面和页脚分班位于顶部和底部,但仍然在页面内容上
例子解释
jQuery Mobile 导航栏
创建导航栏
在内容中的导航栏
在页脚中导航栏
在导航栏中为按钮添加被选外观(被按下)
添加被选外观(被按下)
在导航栏中定位图标
演示在导航栏中的十个按钮
例子解释
jQuery Mobile 可折叠
创建内容可折叠块
当页面加载时展开内容
嵌套的可折叠块
可折叠集合(手风琴)
删除可折叠块上的圆角
使可折叠块更小
改变可折叠块的图标
可折叠列表
可折叠表单
例子解释
jQuery Mobile 网格
两列布局
三列布局
四列布局
五列布局
自定义网格
列中的多行
例子解释
jQuery Mobile 列表
创建列表视图
带有圆角的列表视图
列表分隔符
自动分隔符
创建搜索过滤器
改变搜索框中的文本
创建只读列表
向列表项添加缩略图
使用标准 HTML 来填充带有信息的列表
向列表项添加图标
创建带有分隔按钮的列表
增强列表项的功能性
创建计数泡泡
改变列表项的默认链接图标
可折叠列表
创建日历
例子解释
jQuery Mobile 表单
文本输入
文本框
搜索输入
单选按钮
复选框
对单选按钮和复选框进行水平组合
带有单选按钮和复选框的域包含器
预选的单选按钮和复选框
创建选择菜单
创建带有分隔符的选择菜单 (optgroup)
自定义选择菜单
在选择菜单中选取多个选项
组合选择菜单
水平组合选择菜单
预选一个选项
可折叠表单
创建滑块控件
突出显示截至滑块值的轨道
范围滑块(双重的)
创建切换开关
预选一个切换开关
例子解释
jQuery Mobile 主题
主题 "a"
主题 "b"
主题 "c"
主题 "d"
主题 "e"
主题化的页眉、内容和页脚
主题化的对话框
主题化的按钮
主题化的图标
页眉和页脚中的主题化按钮
主题化的导航栏
主题化的可折叠按钮和内容
主题化的列表
主题化的划分按钮
主题化的可折叠列表
主题化的表单
主题化的可折叠表单
定制主题
例子解释
jQuery Mobile 事件
Tap 事件
Taphold 事件
Swipe 事件
Swipeleft 事件
Swiperight 事件
Scrollstart 事件
Scrollstop 事件
Orientationchange 事件 - 提示方向
Orientationchange 事件 - 为水平和垂直方向设置不同的样式
Page initialization 事件
Page load 事件
Page transition 事件
例子解释
jQuery Mobile Data 属性
jQuery Mobile 实例
jQuery Mobile 事件
jQuery Data 属性
jQuery Mobile 使用 HTML5 data-* 属性为移动设备创建“对触摸友好的”美观的外观。
在下面的参考列表中,粗体值规定默认值。
Button
带有 data-role="button" 的超链接。工具栏中的按钮元素和链接以及输入字段会被自动设置按钮的样式,无需 data-role="button"。
Data 属性 值 描述
data-corners true | false 规定按钮是否有圆角。
data-icon Icons Reference 规定按钮的图标。默认是没有图标。
data-iconpos left | right | top | bottom | notext 规定图标的位置。
data-iconshadow true | false 规定按钮图标是否有阴影。
data-inline true | false 规定按钮是否是行内的。
data-mini true | false 规定按钮是小型的还是常规尺寸的。
data-shadow true | false 规定按钮是否有阴影。
data-theme letter (a-z) 规定按钮的主题颜色。
提示:如需组合多个按钮,请使用带有 data-role="controlgroup" 以及 data-type="horizontal|vertical" 属性的容器,来规定水平还是垂直组合按钮。
Checkbox
label 和 type="checkbox" 的 input 是成对的。会被自动设置为按钮的样式,无需 data-role。
Data 属性 值 描述
data-mini true | false 规定复选框是小型的还是常规尺寸的。
data-role none 防止 jQuery Mobile 将复选框设置为按钮的样式。
data-theme letter (a-z) 规定复选框的主题颜色。
提示:如需组合多个复选框,请使用 data-role="controlgroup" 以及 data-type="horizontal|vertical",来规定水平还是垂直组合复选框。
Collapsible
标题元素,其后是位于带有 data-role="collapsible" 属性的容器中的任意 HTML 标记。
Data 属性 值 描述
data-collapsed true | false 规定内容是否应该关闭或展开。
data-collapsed-icon Icons Reference 规定可折叠按钮的图标。默认是 "plus"。
data-content-theme letter (a-z) 规定可折叠内容的主题颜色。同时会向可折叠内容添加圆角。
data-expanded-icon Icons Reference 规定内容被展开时的可折叠按钮的图标。默认是“减号”。
data-iconpos left | right | top | bottom 规定图标的位置。
data-inset true | false 规定可折叠按钮是否拥有圆角和外边距的样式。
data-mini true | false 规定可折叠按钮是小型的还是常规尺寸的。
data-theme letter (a-z) 规定可折叠按钮的主题颜色。
Collapsible Set
带有 data-role="collapsible-set" 属性的容器中的可折叠内容块。
Data 属性 值 描述
data-collapsed-icon Icons Reference 规定可折叠按钮的图标。默认是“加号”。
data-content-theme letter (a-z) 规定可折叠内容的主题颜色。
data-expanded-icon Icons Reference 规定内容被展开时的可折叠按钮的图标。默认是“减号”。
data-iconpos left | right | top | bottom | notext 规定图标的位置。
data-inset true | false 规定 collapsibles 是否拥有圆角和外边距的样式。
data-mini true | false 规定可折叠按钮是小型的还是常规尺寸的。
data-theme letter (a-z) 规定可折叠集合的主题颜色。
Content
带有 data-role="content" 属性的容器。
Data 属性 值 描述
data-theme letter (a-z) 规定内容的主题颜色。默认是 "c"。
Controlgroup
带有 data-role="controlgroup" 属性的