动态创建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代码展示:
    
    <div id="container" data-PageSwitch>
      <div class="sections">
        <div class="section" id="section0">
          <h3>This is the Page</h3>
        </div>
        <div class="section" id="section1">
          <h3>This is the Page</h3>
        </div>
        <div class="section" id="section2">
          <h3>This is the Page</h3>
        </div>
        <div class="section" id="section3">
          <h3>This is the Page</h3>
        </div>
      </div>
    </div>
  自定义插件的调用方法:
<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的自定义插件:实现整屏分页转换的功能的更多相关文章

  1. 基于jquery下拉列表树插件代码

    分享一款基于jquery下拉列表树插件代码.这是一款实用的jquery 树形下拉框 下拉树代码下载.效果图如下: 在线预览   源码下载 实现的代码. html代码: <table width= ...

  2. 基于jQuery头像裁剪插件cropbox

    今天给大家分享一款基于jQuery头像裁剪插件cropbox,这是一款简单实用的jQuery头像在线裁剪插件.该插件适用于适用浏览器:IE8.360.FireFox.Chrome.Safari.Ope ...

  3. 基于jQuery的用户界面插件集合---EasyUI

    easyui是一种基于jQuery的用户界面插件集合.为创建现代化,互动,JavaScript应用程序,提供必要的功能.使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以 ...

  4. 基于jQuery的tooltips插件--poshytip

    摘要: 分享一款在项目中使用的tooltips插件--poshytip,这是一款基于jQuery的插件,其特点是简单易用,支持浏览器:IE6+, FF 2+, Opera 9+, Safari 3+, ...

  5. jquery自定义插件来实现分页的效果

    本节将介绍如何定义自己的jquery插入,实现分页效果,话不多说,.看看达到的效果: 分页插件 实现的代码例如以下: <!DOCTYPE HTML PUBLIC "-//W3C//DT ...

  6. jquery如何自定义插件(扩展实例/静态方法)

    1.jquery插件的种类: 1).封装对象方法的插件(相当于实例方法) (使用 $.fn.extend({"方法名":function(参数){//方法体} }) ) 2).封装 ...

  7. jQuery开发自定义插件 $.extend()与$.fn.extend()

    jQuery extend()和jQuery.fn.extend() jQuery提供两个用于封装扩展的方法: 1.$.extend(); 扩展jQuery类方法,即jQuery全局方法 (在全局可直 ...

  8. 基于jquery的自定义显示消息数量

    根据需求简单的实现一个小功能控件,暂时不支持扩展 $("xxxxxxx").iconCountPlugin(options, start, isOffset) {//三个参数,自定 ...

  9. 基于Jquery、JqueryUI插件编写

    刚开始编写jquery插件的时候,只是从网上找个模板看着写,并不理解.刚刚仔细把官网的API看了下,突然觉得豁然开朗了.马上放假了想着应该整理整理不然忘了又. How to create a Jque ...

随机推荐

  1. iOS回顾笔记(07) -- UITableView的使用和性能优化

    iOS回顾笔记(07) -- UITableView的使用和性能优化 如果问iOS中最重要的最常用的UI控件是什么,我觉得UITableView当之无愧!似乎所有常规APP都使用到了UITableVi ...

  2. windows phone 8.1开发:触控和指针事件1

    原文出自:http://www.bcmeng.com/windows-phone-touch/ UIElement类的触控事件: ManipulationStarting:当用户将手指放在 IsMan ...

  3. JDK中日期和时间的几个常用类浅析(三)

    java.text.SimpleDateFormat   SimpleDateFormat类是用于把字符串解析成日期时间和把日期时间格式化成字符串的工具类.该类主要和java.util.Date类配合 ...

  4. 当git上文件大小写重命名的修改时(git大小写敏感/默认不敏感),如何提交

    git默认是大小写不敏感!!! 加了感叹号是什么意思呢,意思就是这本身就是一个坑,本人使用的IDE是idea(网上说Eclipse可以避开问题),这个IDE本身就集成了git,但是如果要在termin ...

  5. CentOS 安装 clamav

    1.配置yum源 # cd /etc/yum.repos.d/ # vi dag.repo写入下列内容 #Dag RPM Repository Start[dag]name=Dag RPM Repos ...

  6. HTML5 之文件操作(file)

    前言 在 HTML 文档中 <input type="file"> 标签每出现一次,一个 FileUpload 对象就会被创建. 该元素包含一个文本输入字段,用来输入文 ...

  7. linux—find常见指令用法示例

    Linux下find命令在目录结构中搜索文件,并执行指定的操作.Linux下find命令提供了相当多的查找条件,功能很强大.由于find具有强da的功能,所以它的选项也很多,其中大部分选项都值得我们花 ...

  8. artemplate使用

    最近写了一个菜谱展示的网页,其中用到了artemplate模板,关于artemplate的好处就不多说了,直接上干货 1. <script src="js/template-nativ ...

  9. dotweb——go语言的一个微型web框架(二)启动dotweb

    以上的代码截图表示启动一个dotweb服务,在浏览器里输入127.0.0.1:8080,将会得到一个"index"的页面. app := dotweb.New() dotweb.N ...

  10. python+request+robot framework接口自动化测试

    python+requests实现接口的请求前篇已经介绍,还有不懂或者疑问的可以访问 python+request接口自动化框架 目前我们需要考虑的是如何实现关键字驱动实现接口自动化输出,通过关键字的 ...