谈谈javascript插件的写法
插件顾名思义就是能在一个页面多处使用, 各自按自己的参数配置运行, 并且相互不会冲突.
会写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插件的写法的更多相关文章
- 如何开发原生的 JavaScript 插件(知识点+写法)
一.前言 通过 "WWW" 原则我们来了解 JavaScript 插件这个东西 第一个 W "What" -- 是什么?什么是插件,我就不照搬书本上的抽象概念了 ...
- 开源原生JavaScript插件-CJPCD(省市区联动)
一.前言 上两篇博客笔者对 JavaScript Module 模式,闭包等知识点做了简单介绍之后,我们今天开始正式开发一款属于自己的 JavaScript 插件.由于最近项目刚好用到地区选择这一块的 ...
- 初学者--bootstrap(五)JavaScript插件(上)----在路上(6)
jQuery 插件为 Bootstrap 的组件赋予了“生命”.可以简单地一次性引入所有插件,或者逐个引入到你的页面中. 一:首先要确认的是,单个还是全部引入: JavaScript 插件可以单个引入 ...
- JavaScript插件化开发
大熊君JavaScript插件化开发 一,开篇分析 Hi,大家好!大熊君又和大家见面了,还记得昨天的那篇文章吗------这个系列的开篇(第一季).主要讲述了以“jQuery的方式如何开发插件”, 那 ...
- 谈谈javascript中的prototype与继承
谈谈javascript中的prototype与继承 今天想谈谈javascript中的prototype. 通常来说,javascript中的对象就是一个指向prototype的指针和一个自身的属性 ...
- Bootstrap JavaScript插件
在bs3.X中,提供了12种JavaScript插件,分别是:动画过渡(Transition).模态弹窗(Modal).下拉菜单(Dropdown).滚动侦测(Scrollspy).选项卡(Tab ...
- 推荐13款优秀的Twitter Bootstrap JavaScript插件
Bootstrap是基于HTML,CSS和JavaScript的简洁灵活的流行前端框架及交互组件集,由微博先驱Twitter在2011年8月开源的整套前端解决解决方案,拥有非常完备和详尽的开发文档,有 ...
- ASP.NET MVC使用Bootstrap系列(4)——使用JavaScript插件
阅读目录 序言 Data属性 VS 编程API 下拉菜单(dropdown.js) 模态框(modal.js) 标签页(tab.js) 工具提示(tooltip.js) 弹出框(popover.js) ...
- Bootstrap3.0学习教程十七:JavaScript插件模态框
这篇文章中我们主要来学习一下JavaScipt插件模态框.在学习模态框之前,我们先来了解一下JavaScript插件吧. JavaScript插件概览 插件可以单个引入(使用Bootstrap提供的单 ...
随机推荐
- object-c实现的 在PHP中oauth加密算法
说起这个算法,在php中我是这么实现的 function generateSig ($params, $secret = '') { if (empty($secret)) { ...
- Mongodb学习使用记录
在学习使用Mongodb中,对map和reduce的定义,以及对 mapReduce() 方法的调用: >map #在直接输入map时会出现一个'map is not defined'的异常错误 ...
- Django配置静态文件(CSS\js)及Django调用JS、CSS、图片等静态文件
1 新建一项目: root@python:django-admin.py startproject csstest root@python:cd csstest root@python:ls csst ...
- WPF 中 TreeListView 的使用
前段时间在项目开发中需要用 TreeListView 的功能,于是在网上狂搜一通,倒也找到了几个小例子,但还是满足不了我简单的要求,由于时间紧也只能折中凑合着用了.最近时间比较充裕,把其中的例子整理一 ...
- ScheduledExecutorService的用法——定时执行两个任务
package control; import java.text.DateFormat; import java.text.ParseException; import java.text.Simp ...
- 《WPF程序设计指南》读书笔记——第4章 按钮与其他控件
1.Button类 using System; using System.Windows; using System.Windows.Media; using System.Windows.Input ...
- ffmpeg yuv转h264
ffmpeg -s 176x144 -i container_qcif_176_144.yuv -b:v 7776k -r 25 -vcodec libx264 ds.h264
- cron服务 ubuntu
linux 定时执行crontab crontab -e 进入一个vi 编辑界面 在最后一行加上 */30 * * * * netstat > /tmp/net.log 表示每隔30分就执行n ...
- Java类加载器加载类顺序
java ClassLoader的学习 java是一门解释执行的语言,由开发人员编写好的java源文件先编译成字节码文件.class形式,然后由java虚拟机(JVM)解释执 行,.class字节码文 ...
- SQL重复记录查询(转载)
1.查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 select * from people ) 例二: select * from testtable where ...