插件顾名思义就是能在一个页面多处使用, 各自按自己的参数配置运行, 并且相互不会冲突.
会写javascript插件是进阶js高级的必经之路, 也是自己所学知识的一个典型的综合运用. 如果你还没头绪, 无从下手的话, 不用着急, 今天我们就一起来探讨一下插件的一般写法.

所需技能:
    1.面向对象用法
    2.闭包的理解
    3.变量作用域的理解

以一个tab选项卡的为例:

第一步:

      我们需要写html结构, 假设结构如下:

html结构:

<ul id="tab_nav">
<li class="current">新闻</li>
<li>生活</li>
<li>体育</li>
<li>抽奖</li>
</ul>
<div id="tabs">
<div class="tab_items">
新闻
</div>
<div class="tab_items off">
生活
</div>
<div class="tab_items off">
体育
</div>
<div class="tab_items off">
抽奖
</div>
</div>

第二步:

     写css代码, 这个在这里就省去了, 具体大家自己可以去写下, 简单. 具体看截图.

  

  

第三步:

     写js代码了.

大概就分为这三步, 其中第三步是核心. 当然前两步也是很重要的, 结构的好坏会直接影响你的js实现方式.

主结构:

            //构造函数, 以后每一个tab选项卡的实例都是由他来实例化的.
function Tab(){
//some code
}
//对象原型, 这里主要是一些功能方法.
Tab.prototype = {
//some code } 用法:
new Tab('tab_nav', 'tabs', {可选参数}); //实例一个选项卡, 传入一些参数, 实现一些效果
new Tab('tab_nav2', 'tabs2', {可选参数}); //实例第二个选项卡, 传入一些参数, 实现一些效果
...

以上就是tab选项卡插件的主结构, 下面我们来具体实现.

 js代码:

    function Tab(){
this.init.apply(this, arguments); //用init函数初始化对象属性
} Tab.prototype = {
init: function(ela, elb, paramObj){
//默认参数设置, triggerClass:当前选项的class名字, type:鼠标事件, delay:这个主要针对mouseover快速划过去的一个延时处理
this.defaultOptions = {
triggerClass : 'current',
type : 'mouseover',
delay : 150
}; this.options = this.extend(this.defaultOptions, paramObj || {});
this.oa = document.getElementById(ela);
this.ob = document.getElementById(elb);
this.triggerItem = this.oa.children;
this.listItem = this.ob.children;
this.tLen = this.triggerItem.length;
this.arr = [];
this.timer = null;
this.isIE = !-[1,]; //判断IE浏览器
var self = this;
this.options.delay = this.options.type === 'click' ? 0 : this.options.delay; //当type为click时, 就无延时, 反之则延时
//ie下过滤注释节点
if(this.isIE){
for(var i = 0, len = this.listItem.length; i < len; i++){
if(this.listItem[i].nodeType === 1){
this.arr.push(this.listItem[i]);
}
}
}
for(var i = 0; i < this.tLen; i++){
this.triggerItem[i]['on' + this.options.type] = this.change(i); //绑定事件
this.triggerItem[i].onmouseout = function(){clearTimeout(self.timer); self.timer = null;}; //绑定事件
}
},
extend: function(source, target){ //属性合并处理
for(var p in target){
if(target.hasOwnProperty(p)){
source[p] = target[p];
}
}
return source;
},
trim: function(str){
return str.replace(/^\s+/g, "").replace(/\s+$/g, "");
},
addClass: function(el, name){ //定义添加class函数, addClass(元素对象, class名字)
var arr = [],
str = el.className,
arr = str.split(/\s+/),
len = arr.length,
name = this.trim(name);
for(var i = 0; i < len; i++){
if(arr[i] === name){
return;
}
}
arr.splice(len, 1, name);
el.className = this.trim(arr.join(' '));
el = null;
},
removeClass: function(el, name){ //定义移除class函数, removeClass(元素对象, class名字)
var arr = [],
str = el.className,
arr = str.split(/\s+/),
len = arr.length,
name = this.trim(name);
for(var i = 0; i < len; i++){
if(arr[i] === name){
arr.splice(i,1);
el.className=arr.join(' ');
return;
}
}
},
change: function(d){ //选项卡实现
var self = this;
return function(){
self.timer = setTimeout(function(){
for(var i = 0; i < self.tLen; i++){
if(i === d){
self.addClass(self.triggerItem[d], self.options.triggerClass);
self.isIE ? self.arr[d].style.display = 'block' : self.listItem[d].style.display = 'block';
}
else{
self.removeClass(self.triggerItem[i], self.options.triggerClass);
self.isIE ? self.arr[i].style.display = 'none' : self.listItem[i].style.display = 'none';
}
}
}, self.options.delay);
}
}
}
用法:
new Tab('tab_nav', 'tabs', {type:'click'});
new Tab('tab_nav2', 'tabs2', {triggerClass:'trigger'});
new Tab('tab_nav3', 'tabs3', {type:'mouseover', delay:200});

怎么样,很简单吧,只要思路打开了,就很容易实现了。还有很多其他的方式,有兴趣的大家自己研究研究。

谈谈javascript插件的写法的更多相关文章

  1. 如何开发原生的 JavaScript 插件(知识点+写法)

    一.前言 通过 "WWW" 原则我们来了解 JavaScript 插件这个东西 第一个 W "What" -- 是什么?什么是插件,我就不照搬书本上的抽象概念了 ...

  2. 开源原生JavaScript插件-CJPCD(省市区联动)

    一.前言 上两篇博客笔者对 JavaScript Module 模式,闭包等知识点做了简单介绍之后,我们今天开始正式开发一款属于自己的 JavaScript 插件.由于最近项目刚好用到地区选择这一块的 ...

  3. 初学者--bootstrap(五)JavaScript插件(上)----在路上(6)

    jQuery 插件为 Bootstrap 的组件赋予了“生命”.可以简单地一次性引入所有插件,或者逐个引入到你的页面中. 一:首先要确认的是,单个还是全部引入: JavaScript 插件可以单个引入 ...

  4. JavaScript插件化开发

    大熊君JavaScript插件化开发 一,开篇分析 Hi,大家好!大熊君又和大家见面了,还记得昨天的那篇文章吗------这个系列的开篇(第一季).主要讲述了以“jQuery的方式如何开发插件”, 那 ...

  5. 谈谈javascript中的prototype与继承

    谈谈javascript中的prototype与继承 今天想谈谈javascript中的prototype. 通常来说,javascript中的对象就是一个指向prototype的指针和一个自身的属性 ...

  6. Bootstrap JavaScript插件

      在bs3.X中,提供了12种JavaScript插件,分别是:动画过渡(Transition).模态弹窗(Modal).下拉菜单(Dropdown).滚动侦测(Scrollspy).选项卡(Tab ...

  7. 推荐13款优秀的Twitter Bootstrap JavaScript插件

    Bootstrap是基于HTML,CSS和JavaScript的简洁灵活的流行前端框架及交互组件集,由微博先驱Twitter在2011年8月开源的整套前端解决解决方案,拥有非常完备和详尽的开发文档,有 ...

  8. ASP.NET MVC使用Bootstrap系列(4)——使用JavaScript插件

    阅读目录 序言 Data属性 VS 编程API 下拉菜单(dropdown.js) 模态框(modal.js) 标签页(tab.js) 工具提示(tooltip.js) 弹出框(popover.js) ...

  9. Bootstrap3.0学习教程十七:JavaScript插件模态框

    这篇文章中我们主要来学习一下JavaScipt插件模态框.在学习模态框之前,我们先来了解一下JavaScript插件吧. JavaScript插件概览 插件可以单个引入(使用Bootstrap提供的单 ...

随机推荐

  1. WebApi传递JSON参数

    开发过程中经常进行JSON的传递,在WebApi中传递JSON字串时,会发现服务器端接收到不参数值,看下面代码 服务端: public void Post([FromBody]string value ...

  2. 3.12php

    这是我的第一个博客  纪念一下  反正都是自己看 第一个问题 出现错误 当图片超过1M时就可能出现以下错误  当然这个也跟你php.ini设置有关 如果你php设置里 memory_limit 16M ...

  3. PHPCMS v9栏目添加字段及描述编辑器修改方法

    为PHPCMS v9栏目添加字段和把描述的textarea编辑器变成fceditor编辑器的方法.如下: 1. 添加数据库字段:description1,添加位置:v9_catetory表 2. 在c ...

  4. Cadence封装制作之表贴封装的制作

    以0805封装为例 1.打开PCB editor-> Allegro PCB Design XL 2.File -> New ① Drawing Type -> Package Sy ...

  5. 2014年辛星完全解读Javascript第六节 对象

    随着面向对象的普及,现在很多语言都在支持面向对象,Javascript也不例外,所谓对象,就是拥有属性和方法的数据.这里的属性其实就是变量,这里的方法,其实就是函数.但是Javascript的面向对象 ...

  6. fragment第二次载入就报错

    1.布局中加入一个<fragment 标签,第一次载入的时候是正常的,第二次加载的时候,就直接crashed,退出 2.查到原因Caused by: java.lang.IllegalArgum ...

  7. 黑马程序员 c#单态的设计模式 (专题二)

    <a href="http://edu.csdn.net"target="blank">ASP.Net+Android+IO开发S</a> ...

  8. 【BZOJ 1927】 [Sdoi2010]星际竞速

    Description 10 年一度的银河系赛车大赛又要开始了.作为全银河最盛大的活动之一, 夺得这个项目的冠军无疑是很多人的梦想,来自杰森座 α星的悠悠也是其中之一. 赛车大赛的赛场由 N 颗行星和 ...

  9. iOS开发进阶 - 使用shell脚本自动打包上传到fir.im上-b

    用fir.im测试已经好长时间了,感觉每次打包上传都很麻烦,想着是不是可以用脚本自动打包,在网上搜了一下确实有,下面总结一下如何使用脚本自动打包上传到fir.im,以及打包过程中遇到的问题和解决办法 ...

  10. html 设置Select options值进行绑定

    <select id="cdms"> <option value="">请选择...</option> <option ...