原生Javascript插件开发实践


Posted in Javascript onJanuary 09, 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 Select标记中options操作方法集合
Oct 22 Javascript
jqPlot 基于jquery的画图插件
Apr 26 Javascript
利用jQuery实现可输入搜索文字的下拉框
Oct 23 Javascript
JS全局变量和局部变量最新解析
Jun 24 Javascript
微信js-sdk界面操作接口用法示例
Oct 12 Javascript
用jQuery实现可输入多选下拉组合框实例代码
Jan 18 Javascript
Angular获取手机验证码实现移动端登录注册功能
May 17 Javascript
Angular2开发环境搭建教程之VS Code
Dec 15 Javascript
详解vue表单——小白速看
Apr 08 Javascript
Vue源码解析之数据响应系统的使用
Apr 24 Javascript
vue指令做滚动加载和监听等
May 26 Javascript
jQuery zTree插件使用简单教程
Aug 16 jQuery
Angular下H5上传图片的方法(可多张上传)
Jan 09 #Javascript
详解网站中图片日常使用以及优化手法
Jan 09 #Javascript
jQuery实现表格元素动态创建功能
Jan 09 #Javascript
input输入密码变黑点密文的实现方法
Jan 09 #Javascript
微信小程序 css使用技巧总结
Jan 09 #Javascript
详解Jquery Easyui的验证扩展
Jan 09 #Javascript
Javascript blur与click冲突解决办法
Jan 09 #Javascript
You might like
用穿越火线快速入门php面向对象
2012/02/22 PHP
PHP对文件夹递归执行chmod命令的方法
2015/06/19 PHP
php导出中文内容excel文件类实例
2015/07/06 PHP
JavaScript 函数参数是传值(byVal)还是传址(byRef) 分享
2013/07/02 Javascript
JS实现拖动示例代码
2013/11/01 Javascript
ExtJS判断IE浏览器类型的方法
2014/02/10 Javascript
JavaScript设置获取和设置属性的方法
2015/03/04 Javascript
使用jquery+CSS3实现仿windows10开始菜单的下拉导航菜单特效
2015/09/24 Javascript
BootStrap表单控件之文本域textarea
2017/05/23 Javascript
Angular 2父子组件数据传递之局部变量获取子组件其他成员
2017/07/04 Javascript
ng-repeat指令在迭代对象时的去重方法
2018/10/02 Javascript
微信小程序使用map组件实现检索(定位位置)周边的POI功能示例
2019/01/23 Javascript
微信小程序-可移动菜单的实现过程详解
2019/06/24 Javascript
vue 开发企业微信整合案例分析
2019/12/02 Javascript
[40:05]DOTA2上海特级锦标赛A组小组赛#1 EHOME VS MVP.Phx第一局
2016/02/25 DOTA
深入解析Python中的__builtins__内建对象
2016/06/21 Python
python time.sleep()是睡眠线程还是进程
2019/07/09 Python
mac系统下Redis安装和使用步骤详解
2019/07/09 Python
详解解决Python memory error的问题(四种解决方案)
2019/08/08 Python
wxPython绘图模块wxPyPlot实现数据可视化
2019/11/19 Python
Tensorflow分批量读取数据教程
2020/02/07 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
2020/05/18 Python
Pytorch上下采样函数--interpolate用法
2020/07/07 Python
openCV提取图像中的矩形区域
2020/07/21 Python
Python如何爬取51cto数据并存入MySQL
2020/08/25 Python
详解python使用金山词霸的翻译功能(调试工具断点的使用)
2021/01/07 Python
浅谈CSS3 box-sizing 属性 有趣的盒模型
2019/04/02 HTML / CSS
JOSEPH官网:英国奢侈时尚品牌
2018/01/31 全球购物
锐步英国官网:Reebok英国
2019/11/29 全球购物
高三自我鉴定
2013/10/23 职场文书
简单而又朴实的个人求职信分享
2013/12/12 职场文书
中班中秋节活动反思
2014/02/18 职场文书
党校学习自我鉴定
2014/02/24 职场文书
农民工工资保障承诺书
2015/05/04 职场文书
《学会看病》教学反思
2016/02/17 职场文书
mysql配置SSL证书登录的实现
2021/09/04 MySQL