基于jQuery的自定义插件:实现整屏分页转换的功能
动态创建jQuery插件
一.实现功能:
1.基本功能:自适应式整屏分页功能的实现
2.通过鼠标点击标签页转换分页,支持键盘上下左右键的转换分页,同样支持
鼠标滚轮上下滑动转换分页
3.切屏时的动画效果
4.jQuery实现简单的组件开发
5.本文创建的组件直接绑定在$.fn上,可以在Dom调用
二.主要实现代码
1.创建的分页的默认配置,用户可以修改其内容,来实现不同的内容
```
$.fn.PageSwitch.defaults = {
selectors: { //可以修改页面上的各块的class名
sections: ".sections",
section: ".section",
page: ".pages",
active: ".active"
},
index: 0, //分页页码
easing: "ease", //分页动画的
duration: 500,
loop: false, //代表页面是否可以循环播放
pagination: true, //代表页面是否分页
keyboard: true, //是否能触发键盘事件
direction: "vertical", //分页的方向,默认竖屏,横屏:“herizontal”
callback: "" //翻页完成后的回调函数
}
```
2.创建对象的单例模式
```
$.fn.PageSwitch = function(options) { //单例模式
return this.each(function() {
var me = $(this),
instance = me.data("PageSwitch")
if (!instance) {
instance = new PageSwitch(me, options)
me.data("PageSwitch", instance)
}
//判断传递参数options的类型,如果是字符串,用户就可以直接调用
//pageSwitch.prototype内的方法
if ($.type(options) === "string") return instance[options]();
});
}
```
3.创建Dom中的用到的各种事件方法
```
var PageSwitch = (function() { //以后可以根据需求改善pageSwitch对象
function PageSwitch(element, options) {
this.settings = $.extend(true, $.fn.PageSwitch.defaults, options || {})
this.element = element;
this.init(); //初始化插件
}
PageSwitch.prototype = { //定义插件共有方法
//初始化的方法
// 实现初始化dom结构,布局,分页及绑定事件
init: function() {},
//获取滑动页面的数量
pagesCount: function() {
return this.section.length;
},
//获取滑动的宽度(横屏)或高度(竖屏)
SwitchLength: function() {
return this.direction ? this.element.height() : this.element.width()
},
//向前滑动,上一页
prev: function() {},
//向后滑动,向后一页
next: function() {},
//主要针对横屏情况进行页面布局
_initLayout: function() {},
//实现分页的dom结构及css样式
_initPaging: function() {},
//初始化插件事件
_initEvent: function() {
var me = this;
// 页面的点击事件
me.element.on("click", me.selectors.page + " li", function() {})
//鼠标的滚轮事件
me.element.on("mousewheel DOMMouseScroll", function(e) {})
//键盘事件
if (me.settings.keyboard) {
$(window).on("keydown", function(e) {})
}
//浏览器窗口变化事件
$(window).resize(function() {})
//分屏完成后的执行动画
me.sections.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend", function() {}),
//页面滚动
_scrollPage: function() {}
}
return PageSwitch; //返回PageSwitch对象,重要!!!
})();
```
4.在html调用时,写法如下:
```
主要的html代码展示:
自定义插件的调用方法:
<script>
$("#container").PageSwitch({ //其中的值可以修改,以实现不同的效果
index: 0, //分页页码
easing: "ease", //分页动画的
duration: 500,
loop: false, //代表页面是否可以循环播放
pagination: true, //代表页面是否分页
keyboard: true, //是否能触发键盘事件
direction: "vertical", //分页的方向,默认竖屏,横屏:“herizontal”
callback: "" //翻页完成后的回调函数
})
</script> 内部配置参数时,在整屏页面动画完成后可以定义callback函数,用来实现页面内的一些用户需要的操作,比如动画,css属性动画等
```
github开源代码地址:https://github.com/Hasyou99/jQuery--PageSwitch
基于jQuery的自定义插件:实现整屏分页转换的功能的更多相关文章
- 基于jquery下拉列表树插件代码
分享一款基于jquery下拉列表树插件代码.这是一款实用的jquery 树形下拉框 下拉树代码下载.效果图如下: 在线预览 源码下载 实现的代码. html代码: <table width= ...
- 基于jQuery头像裁剪插件cropbox
今天给大家分享一款基于jQuery头像裁剪插件cropbox,这是一款简单实用的jQuery头像在线裁剪插件.该插件适用于适用浏览器:IE8.360.FireFox.Chrome.Safari.Ope ...
- 基于jQuery的用户界面插件集合---EasyUI
easyui是一种基于jQuery的用户界面插件集合.为创建现代化,互动,JavaScript应用程序,提供必要的功能.使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以 ...
- 基于jQuery的tooltips插件--poshytip
摘要: 分享一款在项目中使用的tooltips插件--poshytip,这是一款基于jQuery的插件,其特点是简单易用,支持浏览器:IE6+, FF 2+, Opera 9+, Safari 3+, ...
- jquery自定义插件来实现分页的效果
本节将介绍如何定义自己的jquery插入,实现分页效果,话不多说,.看看达到的效果: 分页插件 实现的代码例如以下: <!DOCTYPE HTML PUBLIC "-//W3C//DT ...
- jquery如何自定义插件(扩展实例/静态方法)
1.jquery插件的种类: 1).封装对象方法的插件(相当于实例方法) (使用 $.fn.extend({"方法名":function(参数){//方法体} }) ) 2).封装 ...
- jQuery开发自定义插件 $.extend()与$.fn.extend()
jQuery extend()和jQuery.fn.extend() jQuery提供两个用于封装扩展的方法: 1.$.extend(); 扩展jQuery类方法,即jQuery全局方法 (在全局可直 ...
- 基于jquery的自定义显示消息数量
根据需求简单的实现一个小功能控件,暂时不支持扩展 $("xxxxxxx").iconCountPlugin(options, start, isOffset) {//三个参数,自定 ...
- 基于Jquery、JqueryUI插件编写
刚开始编写jquery插件的时候,只是从网上找个模板看着写,并不理解.刚刚仔细把官网的API看了下,突然觉得豁然开朗了.马上放假了想着应该整理整理不然忘了又. How to create a Jque ...
随机推荐
- SSH里面使用jQuery的ajax
今天我真的很兴奋!在我的SSH项目中用jQuery的异步传输成功了,经过一天多的奋战,大工告成! 我的项目需求是在javascript中向我的controller(即:action)中传输form表单 ...
- 利用shell批量改名和linux中取随机数的方法
先批量创建文件 #!/bin/sh if [ ! -d /tmp/chenyao ] then mkdir /tmp/chenyao -p fi cd /tmp/chenyao ..} do touc ...
- Lvs+keepalived+mysql主从热备
p.MsoNormal,li.MsoNormal,div.MsoNormal { margin: 0cm; margin-bottom: .0001pt; text-align: justify; f ...
- 20155304 2016-2017-2 《Java程序设计》第六周学习总结
20155304 2016-2017-2 <Java程序设计>第六周学习总结 教材学习内容总结 第十章 串流设计的概念 无论来源和目的地实体形式是什么,只要取得InputStream和Ou ...
- thinkphp3.2.x多图上传并且生成多张缩略图
html部分 <!DOCTYPE html><html><head><meta http-equiv="Content-Type" con ...
- js面向对象二级菜单
<!DOCTYPE html><html> <head> <meta charset="utf-8" /> <title> ...
- 使用Jersey实现图片服务器与应用服务器分离
现在模拟一下Jersey从客户端发送图片到服务器. 1.Tomcat准备 (1)解压一个新的Tomcat作为图片服务器,然后修改端口号(有3处). (2)然 ...
- [认证授权] 3.基于OAuth2的认证(译)
OAuth 2.0 规范定义了一个授权(delegation)协议,对于使用Web的应用程序和API在网络上传递授权决策非常有用.OAuth被用在各钟各样的应用程序中,包括提供用户认证的机制.这导致许 ...
- TCP/IP笔记(五)IP协议相关技术
IP旨在让最终目标主机收到数据包,但是在这一过程中仅仅有IP时无法实现通信的.必须还要又能够解析主机名称和MACdivide功能,以技术包在发送过程中异常情况处理的功能. 这篇主要介绍下DNS.ARP ...
- Jmeter的逻辑控制器——Controller
逻辑控制器(Logic Controller) --贯穿整个Test Plan中,与各组件执行顺序没关系:目的是用于控制采样器的执行顺序. Simple Controller Simple Contr ...