1.首先在页面上准备一个复选框
<input type="checkbox" class="mycheckbox" />效果:
2.在复选框上运行脚本
$(".mycheckbox").ios6switch();
3.可以一次指定多个复选框
插件启动时会自动检测每个复选框的勾选状态
$(".mycheckboxes").ios6switch();
1.禁用相应的复选框元素
插件启动时会自动检测每个复选框的disable状态
<input type="checkbox" class="disabledemo" disabled="disabled" />
<script>$(".disabledemo").ios6switch();</script>
2.设置已禁用开关的透明度
$(".disabledopacitydemo").ios6switch({
disabledOpacity: 0.75
});
3.动态修改开关的禁用/启用状态
$(".dynamicdisabledemo").ios6switch();
$(".enablebutton").click(function(){
$(".dynamicdisabledemo").trigger("enable");
});
$(".disablebutton").click(function(){
$(".dynamicdisabledemo").trigger("disable");
});
1.设置开关打开部分的颜色
$(".orangeswitch").ios6switch({switchonColor: "#FF7A00"});
$(".greenswitch").ios6switch({switchonColor: "#0DE900"});
$(".fuchsiaswitch").ios6switch({switchonColor: "#FF00FF"});
$(".tealswitch").ios6switch({switchonColor: "#008080"});
2.同时设置开关打开和关闭部分的颜色
$(".cyanfuchsiaswitch").ios6switch({
switchoffColor: "#00FFFF",
switchonColor: "#FF00FF"
});
3.设置标签文字的颜色
$(".textcolorswitch").ios6switch({
switchoffTextColor: "#FF0000",
switchonTextColor: "#7CFC00"
});
4.设置手柄及其按下时的颜色
$(".thumbcolorswitch").ios6switch({
thumbColor: "#FFFF00",
thumbPressedColor: "#DBDB00"
});
5.同时设置手柄打开和关闭状态的颜色
$(".thumbonoffcolorswitch").ios6switch({
thumbColor: "#FF7A00",
thumbPressedColor: "#B35500",
thumbSwitchonColor: "#FF00FF",
thumbSwitchonPressedColor: "#B300B3"
});
单位:像素
$(".largeswitch").ios6switch({size: 40});
$(".smallswitch").ios6switch({size: 16});
$(".yesnolabelswitch").ios6switch({
switchoffText: "off",
switchonText: "on"
});
$(".sounddemo").ios6switch({
sound: "sounds/unlock.mp3"
});
当鼠标按下手柄并拖动超过5像素时,开关进入拖动状态,松开鼠标后,插件将根据手柄所在的位置来判断开关是开启还是关闭。
拖动效果支持移动设备
$(".nodragdemo").ios6switch({
draggable: false
});
1.无动画
$(".noanimatedemo").ios6switch({
animateSpeed: 0
});
2.1000毫秒
单位:毫秒
$(".animatespeeddemo").ios6switch({
animateSpeed: 1000
});
3.匀速运动
$(".linearanimatedemo").ios6switch({
animateEasing: "linear"
});
$(".showboxdemo").ios6switch({
showOriginalCheckbox: true
});
1.打开和关闭
直接在原复选框元素上运行脚本即可
$(".scriptcontroldemo").ios6switch();
$(".switchonbutton").click(function(){
$(".scriptcontroldemo").trigger("switchon");
});
$(".switchoffbutton").click(function(){
$(".scriptcontroldemo").trigger("switchoff");
});
2.打开或关闭
$(".scripttoggledemo").ios6switch();
$(".toggleswitchbutton").click(function(){
$(".scripttoggledemo").trigger("toggleswitch");
});
1.被动取值
直接对原复选框元素进行取值即可
$(".clickcheckdemo").ios6switch();
$(".checkbutton").click(function(){
alert($(".clickcheckdemo")[0].checked);
});
2.主动触发
直接在原复选框元素上绑定onchange事件即可
$(".changecheckdemo").ios6switch();
$(".changecheckdemo")[0].onchange = function(){
$(".checkfield").addClass("checkchanged");
setTimeout(function(){$(".checkfield").removeClass("checkchanged")}, 100);
$(".checkfield")[0].innerHTML = $(".changecheckdemo")[0].checked;
}
删除iOS6Switch,恢复原来的复选框
$(".deletedemo").ios6switch();
$(".deletebutton").click(function(){
$(".deletedemo").trigger("destroy");
});
1.自定义样式示例 - iOS 7 样式
$(".ios7styledemo").ios6switch({
switchonColor: "#64BD63",
addClass:"ios7style"
});
点击此处展开/隐藏CSS部分
.ios6switch.ios7style{
border:1px solid #999999;
}
.ios6switch.ios7style .ios6switch_shadow_and_highlight{
background:none;
}
.ios6switch.ios7style .ios6switch_thumb{
background-image:none;
border:1px solid #999999;
box-shadow:none;
}
2.自定义样式示例 - 全透明样式
$(".bgtransparentdemo").ios6switch({addClass:"transparentbg"});
点击此处展开/隐藏CSS部分
.ios6switch.transparentbg{
border:1px solid #4C566C;
}
.ios6switch.transparentbg .ios6switch_shadow_and_highlight{
background:none;
}
.ios6switch.transparentbg .ios6switch_thumb{
background:none !important;
border:1px solid #4C566C;
box-shadow:none;
}
.ios6switch.transparentbg .ios6switch_switch_off, .ios6switch.transparentbg .ios6switch_switch_on{
color:#4C566C !important;
background:none !important;
}
3.动态改变尺寸
只需要改变开关的高度即可,开关的宽度固定为高度的79/27
$(".changesizedemo").ios6switch({addClass:"changeSize"});
$(".size20button").click(function(){$(".changeSize").animate({height:"20px"})});
$(".size27button").click(function(){$(".changeSize").animate({height:"27px"})});
$(".size40button").click(function(){$(".changeSize").animate({height:"40px"})});
$(".size50button").click(function(){$(".changeSize").animate({height:"50px"})});
4.自定义样式示例 - 使用CSS定义背景1
$(".bgcolorstyledemo").ios6switch({addClass:"huegradient"});
点击此处展开/隐藏CSS部分
.ios6switch.huegradient .ios6switch_switch_off{
background-image: url("");
}
.ios6switch.huegradient .ios6switch_switch_on{
background-image:-webkit-linear-gradient(to bottom, #F00, #FF0, #0F0, #0FF, #00F, #F0F);
background-image:linear-gradient(to bottom, #F00, #FF0, #0F0, #0FF, #00F, #F0F);
}
5.自定义样式示例 - 使用CSS定义背景2
$(".bgpatterndemo").ios6switch({addClass:"patterngradient"});
点击此处展开/隐藏CSS部分
.ios6switch.patterngradient .ios6switch_switch_off{
background-color:#CC1166 !important;
}
.ios6switch.patterngradient .ios6switch_switch_on{
background-color:#026873 !important;
}
.ios6switch.patterngradient .ios6switch_switch_off, .ios6switch.patterngradient .ios6switch_switch_on{
color:#FFFFFF !important;
background-size:20px 20px;
background-image:-webkit-linear-gradient(-45deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
background-image:linear-gradient(135deg, rgba(255, 255, 255, .2) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, .2) 50%, rgba(255, 255, 255, .2) 75%, transparent 75%, transparent);
}
反向
只需要互换打开与关闭部分的样式并且反转true与false的含义即可
$(".invertdemo").ios6switch({
switchonColor: "#FFFFFF",
switchoffColor: "#008AF2",
switchonTextColor: "#555555",
switchoffTextColor: "#FFFFFF",
switchonText: "0",
switchoffText: "1"
});
$(".invertdemo")[0].onchange = function(){
$(".invertcheckfield").addClass("checkchanged");
setTimeout(function(){$(".invertcheckfield").removeClass("checkchanged")}, 100);
$(".invertcheckfield")[0].innerHTML = !$(".invertdemo")[0].checked;
}
默认兼容性:IE9+ Chrome Firefox Safari Opera…
本插件在JS上对IE7/8进行了支持,但是部分核心CSS效果不支持IE7/8(如background-size、border-radius等)
如果要在IE7/8上实现最佳视觉效果,可以参考以下插件:
CSS3 PIE: http://css3pie.com/ background-size polyfill: http://github.com/louisremi/background-size-polyfill
| 选项名称 | 默认值 | 描述 |
| showOriginalCheckbox | false | 是否显示原复选框。 |
| size | 27 | 开关的尺寸。(单位:像素) |
| draggable | true | 是否允许手柄拖动效果。当鼠标按下手柄并拖动超过5像素时,开关进入拖动状态,松开鼠标后,插件将根据手柄所在的位置来判断开关是开启还是关闭,拖动效果支持移动设备。 |
| disabledOpacity | 0.5 | 已禁用开关的透明度。 |
| addClass | "" | 附加到开关元素上的Class,可用于自定义样式等,多个Class请用空格分隔。 |
| sound | "" | 用户操作开关时播放的声音。(指定音频文件的路径,不支持IE8及更低版本的浏览器) |
| animateSpeed | 400 | 滑动动画持续时间。(单位:毫秒) |
| animateEasing | "swing" | 滑动动画的时间曲线,包含swing(缓动)和linear(匀速)两个可用的值。如果要使用更多的动画过渡效果,可以参考 jQuery Easing 插件。 |
| thumbColor | "#FFFFFF" | 手柄在关闭状态下的颜色。 |
| thumbPressedColor | "#CCCCCC" | 手柄在关闭状态下被按下时的颜色。 |
| thumbSwitchonColor | "" | 手柄在打开状态下的颜色。如果此值留空,则会使用与thumbColor相同的颜色。 |
| thumbSwitchonPressedColor | "" | 手柄在打开状态下被按下时的颜色。如果此值留空,则会使用与thumbSwitchonColor相同的颜色。 |
| switchoffTextColor | "#555555" | 关闭标签的文字颜色。 |
| switchonTextColor | "#FFFFFF" | 打开标签的文字颜色。 |
| switchoffText | "0" | 关闭标签的文字。 |
| switchonText | "1" | 打开标签的文字。 |