vuexの使い方を詳しく解説

php中世界最好的语言
リリース: 2018-04-28 13:41:12
オリジナル
1557 人が閲覧しました

今回は、vuex の使い方について詳しく説明し、vuex を使用する際の 注意事項 を紹介します。また、以下は実際の事例ですので、見てみましょう。

1. npm install vuex

2. src の下に新しいフォルダー ストアを作成します (なぜこの言葉なのでしょうか? vuex は、一部のコンポーネントの状態を保存するために使用されます。ストレージ、ウェアハウスを意味します)。ファイル Index.js (なぜ、index.js なのでしょうか? インポートするとき、index という名前のファイルが最初の選択肢になります)

3. Index.js import は vue と vuex をインポートします (import は es6 の構文、es5 は require)、コードは次のとおりです:

ここでのデモは、夜間モードか昼モードかを選択して、アプリのモードを変更するアペラシオンです。

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
 state: {
 night: true,
 text: '白天',
 className: 'morning'
 },
 mutations: {
 increment (state) {
  state.night = !state.night;
  state.text = state.night === true ? '晚上' : '白天';
  state.className = state.night === true ? 'night' : 'morning';
 }
 }
})
ログイン後にコピー

4. main.js import theindex.js コードは次のとおりです:

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'
import App from './App'
import router from './router'
import store from './store' // 会找index.js 
/* eslint-disable no-new */
new Vue({
 el: '#app',
 router,
 store, // 注入根组件,其他子组件 都可以引用
 template: '<App/>',
 components: { App }
})
ログイン後にコピー

5. vuex status の使用

コンポーネント 1:

dom:

<p class="header" :class="model">
ログイン後にコピー

js

computed: {
 model() {
  return this.$store.state.className // 是ninght 还是 morning
 }
 },
ログイン後にコピー

注:

:class="model" このクラスはメソッドにバインドして渡すことができます。パラメータ (直接使用できます) js class="model" 这个class 可以绑定一个方法传参数,可以直接用 js 表达式,可以绑定一个计算属性

组件2:

dom:

<p class=&#39;modal&#39; @click="changeModel">
 <p class="avatar">
 <img src="../../assets/img/logo.png" width="18" height="18">
 </p>
 <p class="name">
 {{currentModel}}
 </p> 
 <!-- vuex 相当于全局注入 vuex 然后取这里面的值 -->
</p>
ログイン後にコピー

js:

computed: {
 currentModel () {
  return this.$store.state.text
 }
 },
 methods: {
 changeModel () {
  // document.body.className='night'
  this.$store.commit('increment')
 }
 }
ログイン後にコピー

注意:

js 中的 currentModel 和 dom 中的 {{ currentModel }} 是一个,和 :class 可以跟表达方法一样 ,可以跟变量 ,表达方法 ,表达式 ( 这里灵活的模版方法,回头查看下源码,然后补充这的说明, vue模版为何如此强大!)

点击事件,触发方法 changeModel ,changeModel 触发 mutation 的方法,显示改变 值 ,这个是固定的语法, this.$store.commit('increment');

increment 可以在定义的时候,设置参数,传参数, this.$store.commit('increment', 'argumnet') , 在 mutation 里面  increment (state , arg) { .. = arg; ....}; (計算されたプロパティをバインドできる

) コンポーネント 2:

dom:rrreee

js:

rrreee

注:

js の currentModel と dom の {{ currentModel }} は同じであり、:class は式メソッドと同じにすることができ、変数とともに使用できます、式メソッド、および式 (ここでは柔軟なテンプレート メソッドです。戻ってソース コードを確認してから、この説明を追加します。なぜ Vue テンプレートが非常に強力なのかを説明します!)

クリック イベント、トリガー メソッド changeModel、changeModel トリガー ミューテーション メソッド、変更された値を表示します。これは固定構文です。this.$store .commit('increment');

increment は、パラメータを設定し、定義時にパラメータを渡すことができます。 this.$store。 commit('increment', 'argumnet') , In mutation increment (state, arg) { .. = arg;

スクリーンショットは次のとおりです。

デフォルトモード: 上に示すとおり。デフォルトは昼間モード、className は朝です。

もう一度クリックすると、index.js の論理メソッドの夜の増分変数と一致するように変更できます。 。 jq の toggle と同様に、

結論:

簡単な vuex のケースをメモします。ご質問がございましたら、メッセージを残していただければ時間内に返信させていただきます。また、スクリプト ハウスの Web サイトをサポートしていただきありがとうございます。 この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書: 🎜🎜🎜vueでの共通コンポーネントの使用方法の詳細な説明🎜🎜🎜🎜🎜 renderを操作するメソッドとは何ですか🎜🎜🎜

以上がvuexの使い方を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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