jquery自定义插件——以 选项卡插件为例
一直打算尝试自定义插件,终于付诸实践了,现在把内容发表出来,与大家共勉。
我是根据自己正在用的插件,模仿其源码,实现的自定义插件,完成之后,在网上看相关资料,对自定义插件部分,有了更明确的认识。
jquery自定义插件的两种方式:
一、jquery对象级插件——调用方法:$("#id").函数名(参数);
(function($){
$.fn.extend({
"函数名":function(自定义参数){
//这里写插件代码
}
}); })(jQuery);
或者
(function($){
$.fn.函数名=function(自定义参数){
//这里写插件代码
}
})(jQuery);
二、jquery类级别的插件——调用方法:$.函数名(参数);
(function($){
$.extend({
"函数名":function(自定义参数){
//这里写插件代码
}
});
})(jQuery);
或者
(function($){
$.函数名=function(自定义参数){
//这里写插件代码
}
})(jQuery);
自定义tab插件
css(jquery.tabs.css)
/**
*tab 容器
*/
.tabs-diy {
width: 500px;
height: 350px;
margin:auto;
border:1px solid #ccc;
}
/**
*tab 选项区
*/
.tabs-diy ul {
width: 500px;
height: 20px;
list-style: none;
margin:0px;
padding:0px;
background-color: #aaa;
}
.tabs-diy ul li{
width: 100px;
height: 20px;
float: left;
text-align: center;
}
.tabs-diy ul li a{
display:block;
width: 100%;
height: 18px;
color: #333;
text-decoration:none;
}
/**
*tab 内容区
*/
.tabs-diy div {
box-sizing: border-box;
width: 500px;
height: 330px;
background-color: #eee;
padding:10px;
}
/**
*tab 选中 样式
*/
.seleted-li {
background-color: #ddd;
}
.seleted-li a {
color:#369;
border-radius:3px;
border:1px solid #999;
}
js(jquery.tabs.js)
(function($) {
$.fn.tabs = function(options) {
var defualts = { };
var opts = $.extend(defualts, options);
var obj = $(this);
var clickIndex = 0;
$("ul li:first", obj).addClass("seleted-li");
$("ul li", obj).not(":first").addClass("unSeleted-li");
$("div", obj).not(":first").hide();
$("ul li", obj).bind("click",function() {
if (clickIndex != $("ul li", obj).index($(this))) {
clickIndex = $("ul li", obj).index($(this));
$(".seleted-li", obj).removeClass("seleted-li");
$(this).addClass("seleted-li");
var divId = $("a", $(this)).attr("content-id");
$("div", obj).hide();
$("#" + divId, obj).show();
};
});
};
$(document).ready(function () {
$('.tabs-diy').each(function () {
var $tabs = $(this);
$tabs.tabs();
});
});
})(jQuery);
html(tabs.html)
<!DOCTYPE html>
<html>
<head>
<title>自定义tab插件</title>
<meta name="keywords" content="keyword1,keyword2,keyword3">
<meta name="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" href="jquery.tabs.css">
</head>
<body>
<div id="mytabs" class="tabs-diy">
<!--选项卡区域-->
<ul>
<li><a content-id="tabs1">选项1</a></li>
<li><a content-id="tabs2">选项2</a></li>
<li><a content-id="tabs3">选项3</a></li>
</ul>
<!--面板区域-->
<div id="tabs1">选项11111111中的内容</div>
<div id="tabs2">选项22222222中的内容</div>
<div id="tabs3">选项33333333中的内容</div>
</div>
<script src="jquery.js"></script>
<script src="jquery.tabs.js"></script>
</body>
</html>
效果图
注意事项:
(1)js,css,html放在同一文件夹下,并要引入jquery.js
(2)如果js,css,html不在同一文件夹下,请更改html中的引用路径。
(3)此结果为试验版,如果觉得样式不好看,可以自己更改。
(该文仅供学习交流。如有不同观点,欢迎留下宝贵意见~)
jquery自定义插件——以 选项卡插件为例的更多相关文章
- jQuery 自定义网页滚动条样式插件 mCustomScrollbar 的介绍和使用方法(转)
系统默认的滚动条样式,真的已经看的够恶心了.试想一下,如果在一个很有特色和创意的网页中,出现了一根系统中默认的滚动条样式,会有多么的别扭. 为了自己定义网页中的滚动条的方法,我真的已经找了很久了,就目 ...
- [js插件开发教程]原生js仿jquery架构扩展开发选项卡插件
jquery插件一般是这么干的: $.fn.插件名称 = function(){}, 把插件的名称加在.fn上,在源码里面实际上是扩展到构造函数的原型对象上,如果你没看过jquery的源代码,或者你曾 ...
- Jquery自定义图片上传插件
1 概述 编写后台网站程序大多数用到文件上传,可是传统的文件上传控件不是外观不够优雅,就是性能不太好看,翻阅众多文件上传控件的文章,发现可以这样去定义一个文件上传控件,实现的文件上传的效果图如下: 2 ...
- jquery自定义banner图滚动插件---(解决最后一张图片倒回第一张图片的bug)
banner图的滚动效果动画 最近做项目中banner滚动的时候遇到了一个小bug,当banner滚动到最后一张图再跳回第一张图时, 会出现默认的倒回第一张图的过渡效果,看了几个插件都是这样,所以自定 ...
- jQuery自定义漂亮的下拉框插件8种效果演示
原始的下拉框不好看这里推荐一个jQuery自定义漂亮的下拉框插件8种效果演示 在线预览 下载地址 实例代码 <!DOCTYPE html> <html lang="en&q ...
- [js插件开发教程]实现一个比较完整的开源级选项卡插件
在这篇文章中,我实现了一个基本的选项卡功能:请猛击后面的链接>> [js插件开发教程]原生js仿jquery架构扩展开发选项卡插件. 还缺少两个常用的切换(自动切换与透明度渐变),当然 ...
- jQuery自定义滚动条样式插件mCustomScrollbar
如果你构建一个很有特色和创意的网页,那么肯定希望定义网页中的滚动条样式,这方面的 jQuery 插件比较不错的,有两个:jScrollPane 和 mCustomScrollbar. 关于 jScro ...
- 使用jQuery开发tab选项卡插件(可以右键关闭多个标签)
在前一篇“使用jQuery开发tab选项卡插件”的基础上添加了tab标签右键关闭菜单功能,菜单主要包括:关闭当前标签.关闭左侧标签.关闭右侧标签.关闭其他.关闭全部. 一.插件效果 二.实现思路 为w ...
- 深入学习jQuery自定义插件
原文地址:jQuery自定义插件学习 1.定义插件的方法 对象级别的插件扩展,即为jQuery类的实例增加方法, 调用:$(选择器).函数名(参数); $(‘#id’).myPlugin(o ...
随机推荐
- webp性能测评
一.测评目的 通过分析webp图片在不同条件下的性能表现,来确定webp图片的适用场景. 二.测评方式 使用控制变量法,分别从以下3点对webp与jpg图片做对比,得出结论. 1.页面图片总体积. 2 ...
- java怎么定义一个二维数组?
java中使用 [][] 来定义二维数组 定义数组时也可同时初始化下面是一些例子float[][] numthree; //定义一个float类型的2维数组numthree=new float[5][ ...
- (49) odoo context操作
* context 这是一个上下文,运用很灵活 * 得到整个context V7 context=dict(context or {}) 这个版本是明传 V8 self.context_ ...
- Mysql 拼接字段查询语句和join查询拼接和时间查询
个人平时记录的,有点乱 1.修改时间字段,如果时间字段的类型是date或者是datetime类型的 update 表名 set 时间字段 = DATE_FORMAT(NOW(),'%Y-%m-%d % ...
- redhat自定义安装必选
redhat自定义安装必选 1.桌面 ked桌面 x 窗口系统 2.应用程序 编辑器 基于文本的互联网 图形互联网 3.服务器 服务器配置工具 万维网服务器 Windows文件 FTP服务器
- JS 面向对象、prototype原型的克隆
JS中的phototype是JS中比较难理解的一个部分 本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个 ...
- java sqlhelper
dbinfo.properties部分: 注意每行末尾不可以有空格 #oracle configure UserName=scott Password=tiger Driver=oracle.jdbc ...
- SwitchHosts—hosts管理利器
SwitchHosts是一个管理.快速切换Hosts小工具,开源软件,一键切换Hosts配置,非常实用,高效.开发Web过程成,部署有多套环境,网址域名都相同,部署在不同的服务器上,有开发环境.测试环 ...
- Linux 文件访问权限
定义:<sys/stat.h> 每个文件有9个访问权限,可将其分为3类: 标记 含义 S_IRUSR 用户读 S_IWUSR 用户写 S_IXUSR 用户执行 S_IRGRP 组读 S_I ...
- mysql数据库使用
C#操作Mysql数据库的存储过程,网址 DATEDIFF() 函数返回两个日期之间的天数. 语法 DATEDIFF(date1,date2) date1 和 date2 参数是合法的日期或日期/时间 ...