ホームページ  >  記事  >  ウェブフロントエンド  >  Vue.js でのステートレス コンポーネントの使用の概要

Vue.js でのステートレス コンポーネントの使用の概要

青灯夜游
青灯夜游転載
2020-09-30 17:48:352484ブラウズ

Vue.js でのステートレス コンポーネントの使用の概要

この記事では、機能コンポーネントについて学習し、Vue のワークフローでステートレス コンポーネントを使用する方法を学習します。 Vue アプリケーションの状態は、コンポーネントの動作を決定するオブジェクトです。 Vue アプリケーションの状態は、コンポーネントがどのようにレンダリングされるか、またはコンポーネントがどの程度動的であるかを示します。

始める前に

コンピュータに次のものが必要です:

node.js 10.x 以降がインストールされています。ターミナル/コマンド プロンプトで次のコマンドを実行すると、node.js がこのバージョンであることを確認できます:

node -v
  • Visual Studio コード エディター (または同様のコード エディター)

  • 最新バージョンの Vue をマシンにグローバルにインストールします

  • Vue CLI 3.0 をマシンにインストールします

これを行うには、まず古い CLI バージョンをアンインストールします:

npm uninstall -g vue-cli

次に、新しいバージョンをインストールします:

npm install -g @vue/cli
npm install

#はじめに: 状態とインスタンスとは何ですか?

Vue アプリケーション状態は、コンポーネントの動作を決定するオブジェクトです。 Vue アプリケーションの状態は、コンポーネントがどのようにレンダリングされるか、またはコンポーネントがどの程度動的であるかを示します。

同時に、vue インスタンスはビューモデルであり、要素を表すテンプレート、ロードされる要素、メソッド、初期化中のライフサイクル フックなど、いくつかのオプションが含まれています。

Vue コンポーネント

js のコンポーネントは通常、受動的です。vue.js では、データ オブジェクトは、概念、計算されたプロパティ、観察方法や観察手順など。さらに、データ値が変更されると、データ オブジェクトが再レンダリングされます。

対照的に、機能コンポーネントは状態を維持しません。

機能コンポーネント

本質的に、機能コンポーネントは、独自のコンポーネントを持つ機能です。機能コンポーネントは状態を保存したり追跡したりしないため、状態やインスタンスを持ちません。また、機能コンポーネント内の構成要素にアクセスすることはできません。

機能コンポーネントはプレゼンテーションのために作成されます。 Vue.js の機能コンポーネントは React.js の機能コンポーネントと似ています。 Vue では、開発者はコンテキストを渡すことで機能コンポーネントを直接使用して、きちんとしたコンポーネントを簡単に構築できます。

文法機能コンポーネント

公式ドキュメントより、機能コンポーネントは次のようになります:

Vue.component('my-component', {
  functional: true,
  // Props are optional
  props: {
    // ...
  },
  // To compensate for the lack of an instance,
  // we are now provided a 2nd context argument.
  render: function (createElement, context) {
    // ...
  }
})

機能コンポーネントの作成##機能コンポーネントを作成するときに覚えておくべき重要なガイドラインの 1 つは、機能プロパティです。関数の属性は、コンポーネントのテンプレート セクションまたはスクリプト セクションで指定します。テンプレート部分の構文は次のようになります:

<template functional>
  <div> <h1> hello world</h1>
  </div>
</template>

次のようにスクリプトのプロパティを指定できます:

export default {
  functional: true,
  render(createElement) {
    return createElement(
      "button", &#39;Click me&#39;
    );
  }
};

機能コンポーネントはなぜ重要ですか? 機能コンポーネントはステートレスであり、データ値が変更されたときに同じ初期化と再レンダリングのプロセスを経ないため、迅速に実行できます。

ほとんどの場合、機能コンポーネントはループ項目を表現または表示するのに役立ちます。

デモこの入門デモでは、単一ページのコンポーネント タイプのデモと、Vue テンプレートを使用した機能コンポーネントのプレゼンテーション関数タイプのデモが表示されます。

単一ページの機能コンポーネント

test.vue

ファイルを開き、次のコード ブロックをファイルにコピーします。 <pre class="brush:js;toolbar:false">&lt;template functional&gt; &lt;div&gt; &lt;p v-for=&quot;brand in props.brands&quot; :key=&quot;brand&quot;&gt;{{brand}} &lt;/p&gt; &lt;/div&gt; &lt;/template&gt; &lt;script&gt; export default { functional: true, name: &amp;#39;Test&amp;#39;, props: { brands: Array } } &lt;/script&gt;</pre> スクリプトとテンプレートの機能インジケーターは、これが機能コンポーネントであることを示します。小道具は引き続き渡すことができることに注意してください。小道具は、機能コンポーネントで渡すことができる唯一のデータ値です。

保持されている一時的なデータ プロパティを循環することもできます。

app.vue

ファイルを開き、次のコード ブロックをそのファイルにコピーします。 <pre class="brush:js;toolbar:false">&lt;template&gt; &lt;div id=&quot;app&quot;&gt; &lt;img alt=&quot;Vue logo&quot; src=&quot;./assets/logo.png&quot;&gt; &lt;Test :brands =&quot;[&amp;#39;Tesla&amp;#39;, &amp;#39;Bentley&amp;#39;, &amp;#39;Ferrari&amp;#39;, &amp;#39;Ford&amp;#39;]&quot;&gt; &lt;/Test&gt; &lt;/div&gt; &lt;/template&gt; &lt;script&gt; import Test from &amp;#39;./components/Test.vue&amp;#39; export default { name: &amp;#39;app&amp;#39;, components: { Test } } &lt;/script&gt; &lt;style&gt; #app { font-family: &amp;#39;Avenir&amp;#39;, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } &lt;/style&gt;</pre>ここでは、コロンで使用されている props 参照が表示されます。

次のコマンドを使用して開発サーバーでアプリケーションを実行します:

npm run serve

ブラウザでの結果は次のようになります:

Vue.js でのステートレス コンポーネントの使用の概要

レンダリング関数メソッド機能コンポーネントにはレンダリング関数を含めることもできます。

開発者は、Vue テンプレートを使用せずに、レンダリング関数を使用して独自の仮想 DOM を作成します。

レンダリング機能を使用して、車のリストの下に新しいボタンを作成します。プロジェクト フォルダーに

example.js

という新しいファイルを作成し、次のコード ブロックをファイルにコピーします。 <pre class="brush:js;toolbar:false">export default { functional: true, render(createElement, { children }) { return createElement(&quot;button&quot;, children); } };</pre> これにより、ボタンを表示する Renders 関数が作成され、子関数が使用されます。要素上のノードをボタンのテキストとして使用します。

app.vue ファイルを開き、次のコード ブロックをファイルにコピーします。

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <Test 
     :brands ="[&#39;Tesla&#39;, &#39;Bentley&#39;, &#39;Ferrari&#39;, &#39;Ford&#39;]">
    </Test>
    <Example>
     Find More Cars
    </Example>
  </div>
</template>
<script>
import Test from &#39;./components/Test.vue&#39;
import Example from &#39;./Example&#39;
export default {
  name: &#39;app&#39;,
  components: {
    Test, Example
  }
}
</script>
<style>
#app {
  font-family: &#39;Avenir&#39;, Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
  margin-top: 60px;
}
</style>

如果再次运行该应用程序,您将看到find more cars(查找更多汽车)子节点现在是按钮的文本。示例组件在检查时显示为功能组件。

Vue.js でのステートレス コンポーネントの使用の概要

添加点击事件

您可以在组件上添加单击事件,并在根组件中包含该方法。但是,您需要render函数中的数据对象参数来访问它。

复制这个在你的example.js文件:

export default {
    functional: true,
    render(createElement, { data, children }) {
      return createElement("button", data, children);
    }
  };

现在,将单击事件添加到根组件中,Vue将识别它。将以下内容复制到您的app.vue文件:

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <Test 
     :brands ="[&#39;Tesla&#39;, &#39;Bentley&#39;, &#39;Ferrari&#39;, &#39;Ford&#39;]">
    </Test>
    <Example @click="callingFunction">
     Find More Cars
    </Example>
  </div>
</template>
<script>
import Test from &#39;./components/Test.vue&#39;
import Example from &#39;./Example&#39;
export default {
  name: &#39;app&#39;,
  components: {
    Test, Example
  },
  methods: {
    callingFunction() {
      console.log("clicked");
    }
  }
}
</script>

除了上面的示例之外,您还可以在官方文档中列出的功能组件中使用其他参数。

结论

这个功能组件的初学者指南可以帮助您实现快速的表示,显示项目的循环,或者显示不需要状态的工作流的简单部分。

相关推荐:

2020年前端vue面试题大汇总(附答案)

vue教程推荐:2020最新的5个vue.js视频教程精选

更多编程相关知识,请访问:编程入门!!

以上がVue.js でのステートレス コンポーネントの使用の概要の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はlogrocket.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。