Vue の高度な構築プロパティの詳細な説明

Vue の高度な構築プロパティの詳細な説明

1. ディレクティブカスタムディレクティブ

Vue フレームワークのコードでは、ネイティブ DOM 操作はほとんど使用されません。これは、ネイティブ DOM 操作が Vue の命令にカプセル化されているためです。たとえば、先ほど見た <div v-text="xxx"></div> 命令には、実際には次の内部操作があります。

div.innerText = xxx; //もちろん、ここでのdivは取得したDOM要素です

Vue はネイティブ DOM 操作を命令にカプセル化します。要素が命令を使用する場合は、HTML テンプレートの要素タグの属性として直接使用できます。シンプルで便利であり、重複を減らします。

しかし、Vue はすべての DOM 操作を考慮して対応する命令にカプセル化することはできません。開発者が実際に使用するまでわからない DOM 操作もあります。そのため、Vue はユーザーが命令をカスタマイズする方法を提供しており、それは大きく分けて次の 2 種類に分けられます。

カスタム命令はカスタム コンポーネントに似ており、グローバルとローカルに分けられます。以下は、文字y印刷するためのカスタム命令vyを例にしています。

グローバル指令

グローバル プロパティは、Vue が提供する特定の関数に登録されます。

Vue.directive("y", {
  挿入: function(el) {
    el.addEventListener("click", () => console.log("y"));
  }
});

ローカル指示

ディレクティブを定義するテンプレートでのみ使用できます

完全版のテンプレート属性に含めることができます

メイン.js

新しいVue({
  テンプレート:`
    <div vy>
      <button>クリック</button>
    </div>
  `、
  ディレクティブ:{
    'y':{
      挿入: function(el) {
        el.addEventListener("click", () => console.log("y"));
      }
    }
  }
}).$mount("#app");

または、不完全なバージョンの.vueファイルのエクスポートデフォルト{}で

アプリ

<テンプレート>
    <div>
      <button vy>クリック</button>
    </div>
</テンプレート>
<スクリプト>
    エクスポートデフォルト{
      ディレクティブ:{
        'y':{
          挿入: function(el) {
            el.addEventListener("click", () => console.log("y"));
          }
        }
      }
    };
</スクリプト>

ディレクティブオプション

命令オブジェクトには5つの関数属性があります

{
    bind: function (el,info,vnode,oldVnode) {}, //要素がメモリ内に作成されたときに実行されます。 insert: function (パラメータは上記と同じ) {}, //要素がページに挿入されたときに実行されます。 update: function (パラメータは上記と同じ) {}, 
    componentUpdated: 関数 (パラメータは上記と同じ) {}, 
    unbind: 関数 (パラメータは上記と同じ) {} //要素が消えたときに実行}

関数属性パラメータでは、el は命令を呼び出す要素を参照し、info にはすべての情報が含まれます。必要な場合は、info で検索するだけです。

2. ミックスイン

ミックスインの主な目的は、構築オプションの重複を減らすことです。重複する構築オプションを別の *.js ファイルに抽出し、それをインポートしてから、ミックスイン属性を通じて構築オプションにミックスすることができます。

minxin は、単純にコピーするのではなく、追加されたミックスインと現在のオプションに基づいてインテリジェントにミックスされるスマート ミックスインです。

3. 継承を拡張する

継承とミックスインは似たような機能を持っていますが、extend の方が抽象的です。どちらも構築オプションの繰り返しを簡素化します。Extend は、元の Vue シェルに基づいて独自に定義されたプロパティを固定プロパティとして追加し、それを使用して Vue オブジェクトを作成するときに Vue を継承するカスタムクラス MyVue を作成できます。

マイビュー

定数MyVue = Vue.extend({
    minxins: [ログ]
});

デフォルトの MyVue をエクスポートします。

4. 提供して注入する

親は共通のデータやメソッドを提供する

{
    //...
    提供する(){
        戻る {
            xx: this.changexx、
            yy: これを変更yy
        }
    },
    方法:{
        チェンジxx(){
            //...
        },
        チェンジ(){
            //...
        }
    }
}

子孫はデータを変更するために何かを注入する

{
    挿入: ["changexx", "changeyy"]
}

これは .sync 修飾子と少し似ていますが、より一般的です。

以上がVueの高度な構造プロパティの詳細な説明です。Vueの高度な構造プロパティの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Vue の計算プロパティとリスナーの使用の概要
  • VueのCSS属性値の1つを動的に変更する
  • Vue の計算プロパティとリスニングプロパティ
  • Vueでループオブジェクトのプロパティと属性値を使用する方法
  • Vueはデータ内の属性値に応じて異なるスタイルを設定することを実装しています
  • vueは、未定義の値、空の値、またはプリミティブ値に対してリアクティブプロパティを設定できない問題を解決します。
  • Vueの計算プロパティとウォッチの違いを簡単に理解する
  • Vue が mapState で定義された属性にエラーを割り当てる問題を解決する
  • Vue 構築オプション - 高度な使用方法の説明

<<:  MySQL8 でパスワードを忘れた後にパスワードをリセットする方法 (MySQL の古い方法は機能しません)

>>:  FileZilla を使用して FTP ファイル サービスを素早く構築する方法

推薦する

基本的な HTML ディレクトリの問題 (相対パスと絶対パスの違い)

相対パス - ファイルを参照する Web ページの場所に基づいて確立されたディレクトリ パス。そのた...

HTML タグ sup と sub の応用の紹介

HTML タグ: 上付き文字HTML では、<sup> タグは上付き文字のテキストを定義...

純粋な CSS3 で蝶が羽ばたく様子を再現する例

純粋なCSS3で蝶が羽ばたく様子を再現。まずはその効果をご覧ください どうですか?効果はかなりいいで...

MySQL で 2 つのテーブルをクエリする場合の from と join の違いの概要

序文MySQL では、複数テーブル結合クエリは非常に一般的な要件です。複数テーブルクエリを使用する場...

数百万のデータボリュームに対する MySQL ページングクエリ方法とその最適化の提案

データベース SQL の最適化はよくある問題です。何百万ものデータ ボリュームに対してページング ク...

Vue-cliフレームワークはタイマーアプリケーションを実装します

技術的背景このアプリケーションは vue-cli フレームワークを使用し、カスタム コンポーネント ...

Vueコンポーネントは、写真やビデオをアップロードするためのサンプルコードをカプセル化します

まず依存関係をダウンロードします: cnpm i -S vue-uuid ali-oss画像フィール...

最適なウェブページ幅とその互換性のある実装方法

1. Web ページをデザインするときに、幅を決定するのは非常に面倒な作業です。 jb51.net ...

MySQLの重複排除方法

MySQLの重複排除方法【初級】繰り返しのセリフが少ないdistinctive を使用してそれらを見...

HTML での一般的なリダイレクト接続の例コード

コードをコピーコードは次のとおりです。 window.location.href="zcb...

フロントエンドエンジニアが作ったクールなインタラクティブウェブサイトを推薦します

ウェブサイトリンク: http://strml.net/サミュエル・リード著ヒント: 昨日、Mome...

TypeScript 学習ノート: 型の絞り込み

目次序文型推論真理値の絞り込み平等の縮小演算子の絞り込みインスタンスの絞り込み狭まりの本質ユニオン型...

a タグをクリックして入力ファイルのアップロードダイアログボックスを表示する方法

htmlコードをコピーコードは次のとおりです。 <SPAN class=tag><...

HttpsページでBaiduシェアを使用するためのソリューション

サイト全体で https アクセスを有効にしてから、共有コードが利用できなくなり、有効になっていた小...

MySQL ディープ ページング (数千万のデータを素早くページ分割する方法)

目次序文場合最適化まとめ序文バックエンド開発では、一度に大量のデータがロードされ、メモリやディスク ...