ホームページ  >  記事  >  ウェブフロントエンド  >  ネイティブ Javascript プラグイン開発の実践

ネイティブ Javascript プラグイン開発の実践

高洛峰
高洛峰オリジナル
2017-01-10 10:58:281181ブラウズ

前書き

以前に会社がデザインした Web サイトは、多くの場所で非常にわかりにくく、一貫性がありませんでした。その理由は、会社の UI が複数の担当者によって変更されたためでした。違うように作りました。最近、会社はこの問題を修正し始めています。このような統一的なものについては、当然モジュールまたはプラグインにする必要があり、プラグインにする予定です。この記事を書いた理由は、このプラグインを作成した後、このプラグインには多くの概念があることに気づきました。このプラグインは複雑ではありませんが、これらの概念を要約したいと思います。

それをどのように構成するか?

私は、建築という概念にあまり触れたことがありませんが、建築とは将来起こるかもしれないことを解決するものだと理解しています。

以前にいくつかのプラグインをカプセル化しましたが、バックエンドは私のカプセル化が難しすぎると考えたので、その理由を分析したところ、以前に作成したプラグインには公開されたインターフェイスと、いくつかのパラメータが含まれていないことがわかりました。渡す必要はありませんでしたが、代わりに渡す必要がありました。公開すべきインターフェースが存在しないのは、将来のことを考えてプラグインを書いていないためであり、このようにして書かれたプラグインは使い捨てになることがよくあります。

そのため、この期間中、プラグインを作成する前に、プラグインがどのパラメータを必要とするか、どのパラメータを渡さなければならないか、どのパラメータがオプションであるか、どの機能が将来使用される可能性があるか、およびどのパラメータを事前に明確に考えます。はい、これらは変更できます。考慮する必要があります。そうしないと、作成されたプラグインに多くの問題が発生することになります。

基本プロトタイプ

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

変数の競合を防ぐために記述するコードを自己実行関数で囲み、このコンストラクターを外部からアクセスできるようにウィンドウ オブジェクトに公開します。

エフェクトは次のように作成する必要があります:

ネイティブ Javascript プラグイン開発の実践

どのようなパラメータが必要か考えてください

この機能は、要素をクリックしてマスクレイヤーをポップアップし、マスクレイヤーをクリックしてマスクレイヤーを削除することです。

したがって、少なくとも 1 つのパラメータが必要であると分析できます。つまり、誰をクリックしてポップアップ レイヤーをポップアップするかを知る必要があり、いくつかのデフォルト パラメータを設定する必要もあります。

;(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");
 }
});

このまとめ

今回改めて分析してみたところ、例えば画像を使わずに の段落を使用する場合など、まだまだ制限が多いことが分かりました。テキスト、どうしたらいいですか?これらはすべて大きな質問であり、実用的なプラグインを作成するには、技術を理解する必要があるだけでなく、包括的な考え方も必要です。したがって、この記事は始まりにすぎず、まだまだ長い道のりがあります。

以上がこの記事の内容です。この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。また、PHP中国語ウェブサイトも応援したいと思っています。

ネイティブ Javascript プラグインの開発実践に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。