原生Javascript插件开发实践


Posted in Javascript onJanuary 18, 2017

前言

之前公司设计的网站比较混乱,很多地方不统一,其中一个就是弹出层,导致这个原因是因为,公司的UI换了好几个人,而他们每个人做出来的都不太一样。最近公司开始整顿这个问题,对于统一的这种东西当然是做成一个模块,或者插件,而我打算做成插件。之所以写这篇文章是因为,当写完这个插件以后,发现其中有不少的理念,而这些理念我想把它总结一下,虽然这个插件并不复杂。

该怎样架构?

对于架构这个概念,接触的比较少,我的理解,架构就是解决未来可能会发生的事。

之前也封装过一些插件,但后端嫌我封装的太难用,于是分析其原因,发现之前写的插件,该暴露的接口没有,有些不需要传的参数反而要传。该暴露的接口没有,这是因为我没有按照未来的思想来写插件,而往往这样写出来的插件就成了一次性用品。

所以这段时间,在写插件之前都会事先思考清楚,这个插件都需要哪些参数,而哪些又是必须传的,哪些是可选的,哪些功能以后可能会用到,哪些是可以会更改的,这些都是必须考虑的,不然写出来的插件肯定会有很多的问题。

基本雏形

;(function(window,document){
 var MaskShare = function(){
 };
 MaskShare.prototype = {};
 window.MaskShare = MaskShare;
}(window,document));

把要写的代码,封闭到一个自执行函数里面,防止变量冲突,然后将这个构造函数暴露给window对象,方便我们在外部去访问这个构造函数。

效果需要做成如下的:

原生Javascript插件开发实践

思考需要哪些参数

这个功能就是点击某个元素,弹出一个遮罩层,点击遮罩层将遮罩层去掉。

因此可以分析出,至少需要一个参数,也就是我们需要知道点击谁弹出弹出层,另外我们还需要配置一些默认参数。

;(function(window,document){
 var MaskShare = function(targetDom,options){
  // 判断是用函数创建的还是用new创建的。这样我们就可以通过MaskShare("dom") 或 new MaskShare("dom")来使用这个插件了
  if(!(this instanceof MaskShare))return new MaskShare(targetDom,options);
  // 参数合并
  this.options = this.extend({
      // 这个参数以后可能会更改所以暴露出去
   imgSrc:"../static/img/coupon-mask_1.png"
  },options);
  // 判断传进来的是DOM还是字符串
  if((typeof targetDom)==="string"){
   this.targetDom = document.querySelector(targetDom);
  }else{
   this.targetDom = targetDom;
  }
  var boxDom = document.createElement("div");
  var imgDom = document.createElement("img");
  // 设置默认样式 注意将z-index值设置大一些,防止其他元素层级比遮罩层高
  boxDom.style.cssText = "display: none;position: absolute;left: 0;top: 0;width: 100%;height:100%;background-color: rgba(0,0,0,0.8);z-index:9999;";
  imgDom.style.cssText = "margin-top:20px;width: 100%;";
  // 追加或重设其样式
  if(this.options.boxDomStyle){
   this.setStyle(boxDom,this.options.boxDomStyle);
  }
  if(this.options.imgDomStyle){
   this.setStyle(imgDom,this.options.imgDomStyle);
  }
  imgDom.src = this.options.imgSrc;
  boxDom.appendChild(imgDom);
  this.boxDom = boxDom;
  // 初始化
  this.init();
 };
 MaskShare.prototype = {
  init:function(){
   this.event();
  },
  extend:function(obj,obj2){
   for(var k in obj2){
    obj[k] = obj2[k];
   }
   return obj;
  },
  setStyle:function(dom,objStyle){
   for(var k in objStyle){
    dom.style[k] = objStyle[k];
   }
  },
  event:function(){
   var _this = this;
   this.targetDom.addEventListener("click",function(){
    document.body.appendChild(_this.boxDom);
    _this.boxDom.style.display = "block";
        // 打开遮罩层的回调
    _this.options.open&&_this.options.open();
   },false);
   this.boxDom.addEventListener("click",function(){
    this.style.display = "none";
        // 关闭遮罩层的回调
    _this.options.close&&_this.options.close();
   },false);
  }
 };
 // 暴露方法
 window.MaskShare = MaskShare;
}(window,document));

使用示例:

MaskShare(".immediately",{
 imgSrc:"../static/img/loading_icon.gif",
 boxDomStyle:{
  opacity:".9"
 },
 imgDomStyle:{
  opacity:".8"
 },
 open:function(){
  console.log("show");
 },
 close:function(){
  console.log("close");
 }
});

本次总结

此时再分析一遍,发现其还是有很多局限性,比如,如果不使用图片用到的是一段文字呢,又该怎么办?这些都是很大的问题,要写出一个实用的插件,不仅仅技术需要过关,思考还得全面性。所以这篇文章还只是刚刚开始,路还远着呢。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript实现的网页局布刷新效果
Dec 01 Javascript
extJs 下拉框联动实现代码
Apr 09 Javascript
JQUERY dialog的用法详细解析
Dec 19 Javascript
js无刷新操作table的行和列
Mar 27 Javascript
JavaScript中的单引号和双引号报错的解决方法
Sep 01 Javascript
简介JavaScript中的setTime()方法的使用
Jun 11 Javascript
Javascript中indexOf()和lastIndexOf应用方法实例
Aug 24 Javascript
Vue.js基础指令实例讲解(各种数据绑定、表单渲染大总结)
Jul 03 Javascript
mpvue+vant app搭建微信小程序的方法步骤
Feb 11 Javascript
解决vue admin element noCache设置无效的问题
Nov 12 Javascript
JS异步宏队列与微队列原理区别详解
Jul 02 Javascript
Js图片点击切换轮播实现代码
Jul 27 Javascript
js实现炫酷的左右轮播图
Jan 18 #Javascript
jQuery实现别踩白块儿网页版小游戏
Jan 18 #Javascript
工厂模式在JS中的实践
Jan 18 #Javascript
基于jQuery制作小图标上下滑动特效
Jan 18 #Javascript
JQuery Dialog对话框 不能通过Esc关闭的原因分析及解决办法
Jan 18 #Javascript
动态加载css方法实现和深入解析
Jan 18 #Javascript
用jQuery实现可输入多选下拉组合框实例代码
Jan 18 #Javascript
You might like
德生S2000收音机更换“钕铁硼”全频扬声器
2021/03/02 无线电
用mysql内存表来代替php session的类
2009/02/01 PHP
组合算法的PHP解答方法
2012/02/04 PHP
PHP迭代器的内部执行过程详解
2013/11/12 PHP
PHP实现取得HTTP请求的原文
2014/08/18 PHP
PHP中$this和$that指针使用实例
2015/01/06 PHP
php的无刷新操作实现方法分析
2020/02/28 PHP
PHP强制转化的形式整理
2020/05/22 PHP
JavaScript面向对象之体会[总结]
2008/11/13 Javascript
基于jQuery实现模拟页面加载进度条
2013/04/01 Javascript
Node.js生成HttpStatusCode辅助类发布到npm
2013/04/09 Javascript
js创建对象几种方式的优缺点对比
2016/09/28 Javascript
angular2倒计时组件使用详解
2017/01/12 Javascript
jQuery中过滤器的基本用法示例
2017/10/11 jQuery
ES6 javascript中class静态方法、属性与实例属性用法示例
2017/10/30 Javascript
浅析Visual Studio Code断点调试Vue
2018/02/27 Javascript
jQuery实现图片简单轮播功能示例
2018/08/13 jQuery
Vue-Quill-Editor富文本编辑器的使用教程
2018/09/21 Javascript
解决axios post 后端无法接收数据的问题
2019/10/29 Javascript
微信小程序中使用 async/await的方法实例分析
2020/05/06 Javascript
Vue实现返回顶部按钮实例代码
2020/10/21 Javascript
[50:38]DOTA2-DPC中国联赛 正赛 Phoenix vs CDEC BO3 第二场 3月7日
2021/03/11 DOTA
Python的Flask框架中使用Flask-SQLAlchemy管理数据库的教程
2016/06/14 Python
python多线程之事件Event的使用详解
2018/04/27 Python
centos6.5安装python3.7.1之后无法使用pip的解决方案
2019/02/14 Python
python读写csv文件方法详细总结
2019/07/05 Python
Python 整行读取文本方法并去掉readlines换行\n操作
2020/09/03 Python
西北政法大学自主招生自荐信
2014/01/29 职场文书
建筑投标担保书
2014/05/20 职场文书
党建目标管理责任书
2014/07/25 职场文书
居委会工作总结2015
2015/05/18 职场文书
单独二胎证明
2015/06/24 职场文书
2016年共产党员公开承诺书
2016/03/24 职场文书
关于战胜挫折的名言警句大全!
2019/07/05 职场文书
导游词之南京夫子庙
2019/12/09 职场文书
sass 常用备忘案例详解
2021/09/15 HTML / CSS