ホームページ > ウェブフロントエンド > Vue.js > vue.js を使用する場合

vue.js を使用する場合

coldplay.xixi
リリース: 2023-01-13 00:44:49
オリジナル
2566 人が閲覧しました

vue.js の使用: 1. アプリケーションを構築するためにテンプレートを使用する必要がある場合は、Vue を選択してください; 2. 通常動作する単純なものが必要な場合は、Vue を選択してください; 3. 必要な場合は、プログラムをより小さく、より速く更新するには、[Vue] を選択します。

vue.js を使用する場合

このチュートリアルの動作環境: Windows 7 システム、Vue バージョン 2.9.6。この方法は、すべてのブランドのコンピューターに適しています。

[関連記事の推奨事項: vue.js]

vue.js の使用:

次の場合一流の SPA (シングル ページ アプリケーション) を作成するために、軽量で高速かつ最新の UI ライブラリが必要な場合は、Vue.js を選択する必要があります。これは、HTML の操作に慣れている開発者にとって有利です。さらに、コンポーネントの再利用性が提供されるため、開発者は Web アプリケーションで比類のないユーザー エクスペリエンスを構築することができます。

1. アプリケーションを構築するためにテンプレートを使用したい (またはいくつかのオプションが必要な) 場合は、Vue を選択してください

HTML ファイルにマークアップを入れるのは Vue ですアプリケーションのデフォルトのオプション。 Angular と同様に、中括弧はデータ バインディング式に使用され、ディレクティブ (特別な HTML 属性) はテンプレートに機能を追加するために使用されます。以下は簡単な Vue プログラムの例です。動的にメッセージを反転するボタンを備えたメッセージを出力できます。

<div id="app">
  <p>{{ message }}</p>
  <button v-on:click="reverseMessage">Reverse Message</button>
</div>
new Vue({
  el: &#39;#app&#39;,
  data: {    message: &#39;Hello Vue.js!
  },
  methods: {
    reverseMessage: function () {
      this.message = this.message.split(&#39;&#39;).reverse().join(&#39;&#39;);
    }
  }
});
ログイン後にコピー

対照的に、React アプリケーションはテンプレートを回避し、開発者は JavaScript で DOM を作成する必要があります。多くの場合、JSX の支援を受けます。以下の「React を使用して、同じ機能:

class App extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      message: &#39;Hello React.js!&#39;
    };
  }
  reverseMessage() {
    this.setState({ 
      message: this.state.message.split(&#39;&#39;).reverse().join(&#39;&#39;) 
    });
  }
  render() {
    return (
      <div>
        <p>{this.state.message}</p>
        <button onClick={() => this.reverseMessage()}>
          Reverse Message
        </button>
      </div>
    )
  }
}
ReactDOM.render(App, document.getElementById(&#39;app&#39;));
ログイン後にコピー

テンプレートは、標準を学習しているジュニア Web 開発者にとって理解しやすいものです。しかし、テンプレートを使用することに満足している経験豊富な開発者もたくさんいます。テンプレートを使用すると、レイアウトと機能をより適切に分離でき、Pug のようなプリプロセッサを使用するオプションもあるからです。

ただし、テンプレートを使用するには、すべての HTML 拡張構文を学習する必要があり、レンダリング関数は標準の HTML と JavaScript を理解するだけで済みます。

2. 通常どおりに動作する単純なものが好みの場合は、次に、Vue を選択してください

単純な Vue プロジェクトは解析せずにブラウザで直接実行でき、jQuery のようにプロジェクト内で Vue を参照できます。

React を使用することは技術的には可能ですが、一般的な React コードは、クラスや非エミュレート配列メソッドなどの JSX および ES6 機能に重点を置いています。しかし、Vue はシンプルなデザインの中にさらに奥深く入り込んでいます。両者がアプリケーションのデータ (つまり「状態」) をどのように処理するかを比較してみましょう。

State は React で直接変更することはできません。setState インターフェイスを呼び出す必要があります:

this.setState({ 
    message: this.state.message.split(&#39;&#39;).reverse().join(&#39;&#39;) 
});
ログイン後にコピー

現在の状態と以前の状態の違いにより、React は DOM 内でいつ、何を再レンダリングするかを知ることができます。したがって、不変状態は非常に必要です。

対照的に、Vue ではデータを変更できます。 Vue では同じデータ属性を変更する方が簡単です。

// Note that data properties are available as properties of 
// the Vue instance
this.message = this.message.split(&#39;&#39;).reverse().join(&#39;&#39;);
ログイン後にコピー

Vue レンダリング システムが React レンダリングよりも効率が悪いと結論付ける前に、Vue の状態管理を見てみましょう。新しいオブジェクトを状態に追加すると、Vue はそのすべてのプロパティを反復処理して変換します。ゲッターとセッターに。 Vue システムは継続的に状態を追跡し、状態が変化すると自動的に DOM を再レンダリングします。

印象的なのは、Vue の状態変化はより簡潔であるにもかかわらず、再レンダリング システムの効率が実際に React よりも優れていることです。

Vue の反応システムには注目に値する点があります。たとえば、属性の追加、削除、および特定の配列への変更は検出できません。この場合、Vue API で React に似た set メソッドを使用できます。

3. プログラムをより小さく、より高速にしたい場合は、Vue を選択してください。

React と Vue は両方とも仮想 DOM を構築し、アプリケーション状態で作成します。変更時に実際の DOM を同期的に更新します。どちらも独自の最適化メソッドを持っています。 Vue のコア開発者は、Vue のレンダリング システムが React のレンダリング システムよりも高速であることを示すベンチマークを提供しました。このテストでは、10,000 項目のリストが 100 回レンダリングされました。比較結果を以下の表に示します。

vue.js を使用する場合

実用的な観点から見ると、この種のベンチマークはエッジ ケースにのみ関連します。ほとんどのアプリケーションではこれを頻繁に行う必要はないため、比較すると重要な要素とはみなされません。

ページのサイズはプロジェクトに関係しますが、Vue には利点があります。現在リリースされている Vue ライブラリはわずか 25.6KB です。

React で同様の機能を実現するには、React DOM (37.4KB) と React with Addons ライブラリ (11.4KB) を使用する必要があります。合計 48.8KB で、Vue のほぼ 2 倍のサイズになります。公平を期すために言うと、React ではより多くの API を利用できますが、機能が 2 倍になるわけではありません。

関連する無料学習の推奨事項: javascript(ビデオ)

以上がvue.js を使用する場合の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート