关于jQuery写插件及其演示
关于写jQuery插件是非常有必要的。这是前端学习其中必须经过的一个过程
对于初次写插件先想清楚原理
(function($){
$.fn.yourName = function(options){
//各种属性、參数
}
var options = $.extend(defaults, options);
this.each(function(){
//插件实现代码
});
};
})(jQuery);
这是一个基础的模板
当中的var options = $.extend(defaults, options);
1.$.extend()方法
$.extend()方法在JQuery中有两个使用方法。第一次是扩展方法。
第二个方法是
jQuery.extend([deep], target, object1, [objectN])
返回值:Object
把2个对象合并得到新的target,deep是可选的(递归合并)
合并 settings 和 options,改动并返回 settings。
jQuery 代码:
var settings = { validate: false, limit: 5, name: "foo" };
var options = { validate: true, name: "bar" };
jQuery.extend(settings, options);
结果:
settings == { validate: true, limit: 5, name: "bar" }
描写叙述:
合并 defaults 和 options, 不改动 defaults。
jQuery 代码:
var empty = {};
var defaults = { validate: false, limit: 5, name: "foo" };
var options = { validate: true, name: "bar" };
var settings = jQuery.extend(empty, defaults, options);
结果:
settings == { validate: true, limit: 5, name: "bar" }
empty == { validate: true, limit: 5, name: "bar" }
2中扩展:
第一种。看代码
$( function (){ |
jQuery.extend({ |
modalshow: function (options) { |
var defaults = { |
triggerID: 'LoginShow' , |
callback: function () { } |
}<br> //这里是$.extend的另外一种使用方法<br> var opts = $.extend({},defaults, options); |
if ($( "#" + opts.triggerID)[0] == null ) |
var $triggerBTN = $( '<input type="button" value="LoginShow" id=' + opts.triggerID '/>' ); |
$triggerBTN.bind( "click" , function () |
alert(opts.triggerID); |
}); |
$( "body" ).append($triggerBTN); |
} else { |
$( "#" + opts.triggerID).bind( "click" , function () |
alert(opts.triggerID); |
}) |
} |
} |
}); |
$.modalshow(); //这里是调用的地方,id为'loginshow'的button能够先不再HTML中加入能够自己主动生成 |
}) |
另外一种扩展
$( function (){ |
jQuery.fn.extend({ |
modalshow: function (options) { |
var defaults = { |
//这里的this是JQuery对象 |
triggerID: this .attr( "id" ), |
callback: function () { } |
}<br> //这里是$.extend的另外一种使用方法<br> var opts = $.extend(defaults, options); |
$( "#" + opts.triggerID).bind( "click" , function () |
alert(opts.triggerID); |
}) |
} |
}); |
$( "#loginShow" ).modalshow(); //这里是调用的地方。这里须要先在HTML中增加元素 |
}) |
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题</title>
<style type="text/css">
*{
padding:0px;
margin: 0px;
}
.clear{
clear: both;
}
.menu li{
float: left;
width: 100px;
height: 30px;
line-height: 30px;
border:1px solid #ccc;
border-bottom: 5px solid #ccc;;
}
.main{
margin-top: 0px;
width: 406px;
height: 206px;
overflow: hidden;
}
.main div{
width: 403px;
height: 200px;
line-height: 200px;
text-align: center;
border:1px solid #000;
}
.menu .on{
border-bottom: 6px solid red;
}
</style>
<script type="text/javascript" src="Jquery.js"></script>
<script type="text/javascript" src="Tab.js"></script>
</head>
<body>
<div class="tabs">
<ul class="menu">
<li class="on">111</li>
<li>222</li>
<li>333</li>
<div class="clear"></div>
</ul>
<div class="main">
<div class="tab">AAA</div>
<div class="tab">BBB</div>
<div class="tab">CCC</div>
</div>
</div>
<script type="text/javascript">
$(document).ready(function() {
$('.tabs').myTab({
operate:'mouseover',
auto:false,
time:1000,
delay:true,
delaytime:0
})
//利用闭包的原理,对于myTab函数中的一些元素进行初始化
});
</script>
</body>
/***
* 标题:选项卡插件
* 编写时间:2015年7月14号
* 作者:Helios
* 邮箱:67487158@qq.com
***/
;(function($){
$.fn.myTab=function(options){
return this.each(function(){
var defaults={
operate: 'click',
auto: true,
time: 4000,
delay: true,
delayTime: 500
}
var opts = $.extend(defaults, options), //这里面两个參数的顺序不能改变。由于后面的那个时不会被覆盖掉的
//$.extend(defaults, options);表示的是假设options中的參数总是有值的话。那么options中的值将会取代defaults中的值
//假设options參数传入的值为空,那么就能够使用默认设置的值。
self = $(this), //获取当前的tabs
items = self.children('ul.menu').children('li'), //获取上面的是那三个
tabBox = self.children('div.main'), //获取到了main这个节点
tabBoxItems = tabBox.children('div'), // 获取mian以下的div
timer; //设置了一个定时器
var tabHandle = function(index){ //这是进行函数对选中的li和相应的div进行变换
items.siblings('li').removeClass('on').end().eq(index).addClass('on');
tabBoxItems.siblings().hide().end().eq(index).show();
//end()函数的使用方法,就是结束对当前节点的操作继续对曾经的那个节点继续操作
},
delay = function(elem){ //这个延时函数
opts.delay ?
setTimeout(function(){tabHandle(elem);},opts.delaytime) :tabHandle(elem);
},
start = function(){ //開始函数 假设參数设置了自己主动 就运行以下的第二行代码,假设没有设置的话就开启了定时器
if(!opts.auto) return ;
setInterval(autoRun,opts.time);
},
autoRun =function(){ //自己主动播放函数
var on = self.find('li.on'), //获取当前on所在的li
firstItem = items.eq(0),//设置默认第一个li
len = items.length, //
index = on.index()+1,
item = index ===len ? firstItem : on.next('li'), //当前的索引假设等于li的总长度就返回默认的第一个,假设不是就是下一个
i = index ===len ?
0 : index; // 假设播放到了最后一个就跳转到第一个
on.removeClass('on'); //移除当前li上面的样式
item.addClass('on'); //把该选中的添加样式
tabBoxItems.siblings().hide().end().eq(index).show(); // 更换div中的内容 和tabHandle 运行一样的操作
}
//bind() 方法为被选元素加入一个或多个事件处理程序,并规定事件发生时执行的函数。
//第一个參数传递事件,第二个參数还改事件相应的函数
items.bind(opts.operate, function () {
var index = items.index($(this));
delay(index)
});
if (opts.auto) { //假设设置了auto的话推断成功
start();
self.hover(function () {
clearInterval(timer);
timer = undefined;
}, function () {
start();
})
}
})
}
})(jQuery);
关于jQuery写插件及其演示的更多相关文章
- 为jQuery写插件
很多场合,我们都会调用jQuery的插件去完成某个功能,比如slider. 如下图,做一个div,通过“$( "#slider" ).slider();”的方式直接将div变成sl ...
- 实时更新数据的jQuery图表插件DEMO演示
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- jQuery导航插件One-Page-Nav演示-显示命名锚记
jQuery导航插件One-Page-Nav演示-显示命名锚记 简介 使用 选项 示例 推荐 简介 电商网站的分类比较明确,比如1楼是手机通讯产品,2楼是家用电器,3楼是服装鞋包等等,旁边还会有一个固 ...
- jquery写插件
http://www.cnblogs.com/ajianbeyourself/p/5815689.html
- 如何使用jQuery写一个jQuery插件
jQuery插件其实是前端框架的思维,构成一个框架,个人认为必须满足以下几个基础条件:1. 可重用,2. 兼容性,3. 维护方便,虽说现在有很多比较成熟的前端框架,但是也有部分存在配置麻烦,学习成本大 ...
- 自己动手写插件底层篇—基于jquery移动插件实现
序言 本章作为自己动手写插件的第一篇文章,会尽可能的详细描述一些实现的方式和预备知识的讲解,随着知识点积累的一点点深入,可能到了后期讲解也会有所跳跃.所以,希望知识点不是很扎实的读者或者是初学者,不要 ...
- jquery.fullPage.js全屏滚动插件教程演示
css部分(此处需要导入jquery.fullPage.css) <style> .section { text-align: center; font: 50px "Micro ...
- 分享7款非常实用的jQuery/CSS3插件演示和源码
上次我们分享了15款效果很酷的最新jQuery/CSS3特效,非常不错,今天要分享7个非常实用的jQuery/CSS3插件演示和源码,一起来看看. 1.jQuery ajax点击地图显示商家网点分布 ...
- 用jQuery写了一个模态框插件
用jQuery写了一个模态框插件 大家觉得下面的框框好看么, 水印可以去掉(这个任务交给你们了(- o -)~zZ); "info"框 $("div").con ...
随机推荐
- 浅谈2015新版 U-Boot
过了挺长一断时间没有看U-BOOT了,这两天下载了新版的UBOOT源码(之前看的一些书都是基于早好多年的源码来讲述,总感觉心里有点不对劲,也许是我比较喜新的原因吧,不过小弟我并没有厌旧哈),好了不多扯 ...
- call, apply, bind 区别
#call, apply, bind 区别及模拟实现call apply bind 三者都可以用来改变this的指向,但是在用法上略有不同 首先说一下call和apply的区别 call和apply ...
- [bzoj4816][Sdoi2017]数字表格 (反演+逆元)
(真不想做莫比乌斯了) 首先根据题意写出式子 ∏(i=1~n)∏(j=1~m)f[gcd(i,j)] 很明显的f可以预处理出来,解决 根据套路分析,我们可以先枚举gcd(i,j)==d ∏(d=1~n ...
- tensorflow ConfigProto
tf.ConfigProto一般用在创建session的时候.用来对session进行参数配置 with tf.Session(config = tf.ConfigProto(...),...)#tf ...
- 如何把datetime类型字段修改为int类型
如何把datetime类型字段修改为int类型 我有一个表为:table1 其中有一个datetime类型的字段 a 现在我想我想把字段a的类型改为int类型 当我执行以下命令时报如下的错误a ...
- JAVA基础——数据流
DataInputStream 类和DataOutputStream 类 在前面的学习中,我们知道数据流处理的数据都是指字节或字节数组,但实际上很多时候不是这样的,它需要数据流能直接读.写各种各样的j ...
- rem怎么算
* rem : html根标签的 font-size决定* em 相对于父标签的font-size 决定的* 设计稿的宽一般都是 750px ---> 20px* 750px 1rem = 10 ...
- 启用Windows10的Linux子系统并安装图形界面
前言 目前市面上的PC电脑主要运行着四大类系统,它们分别是微软的Windows.苹果的MacOS.Linux的发行版以及Unix类系统.其中Linux和Unix都是开源的,因此市面出现的众多基于Lin ...
- Linux中CentOS网络配置以及与Xshell建立远程连接
为centos配置网络 (1)第一步 点开虚拟机的设置,如下图做相关的设置: 网络连接要选择桥接模式,其他的勾选就按照上图的即可,勾选完成点击确定. (2)第二步 点击VMware的编辑选项,找到“虚 ...
- CSS实现折叠面板
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...