今回は、Vuex をゼロから始める場合の注意点について説明します。以下は実際のケースです。
Vuexとは何ですか?
vuex は、vue.js 用に特別に設計された集中状態管理アーキテクチャです。州?データ内の属性を他の Vue コンポーネントと共有する必要がある部分、つまり状態と呼ばれるものだと私は理解しています。簡単に言えば、データ内で共有する必要があるのは属性です。
Vuex を導入します (プロジェクトが Vue スキャフォールディング ツールで構築されている場合)
1. npm パッケージ管理ツールを使用して vuex をインストールします。制御コマンドラインに次のコマンドを入力するだけです。
npm install vuex --save
パッケージを運用環境で使用するため、ここで –save を追加する必要があることに注意してください。
2. 新しいストアフォルダーを作成し (これは必須ではありません)、そのフォルダーの下に新しい store.js ファイルを作成し、そのファイルに vue と vuex を導入します。
import Vue from 'vue'; import Vuex from 'vuex';
3. vuex を使用し、インポート後に Vue.use を使用して参照します。
import Vue from 'vue'; import Vuex from 'vuex';
この 3 つのステップを経て、vuex 参照が成功したとしても、後は楽しむことができます。
4. 新しい vuex ファイルを main.js に導入します
import storeConfig from './vuex/store'
5. 次に、Vue オブジェクトをインスタンス化するときにストア オブジェクトを追加します。定数オブジェクトを .js ファイルに追加します。 store.js ファイルは、vuex を導入したときのファイルです。
new Vue({ el: '#app', router, store,//使用store template: '<app></app>', components: { App } })
2. エクスポートデフォルトを使用してコードをカプセル化し、外部から参照できるようにします。 const state = {
count:1
}
3. count.vue という名前の新しい vue テンプレートをコンポーネントフォルダーに作成します。テンプレートでは、作成したばかりの store.js ファイルを導入し、{{$store.state.count}}
を使用してテンプレート内のカウント値を出力します。 export default new Vuex.Store({
state
});
4. store.js ファイルに状態を変更する 2 つのメソッドを追加します。
<template> <p> </p> <h2 id="msg">{{msg}}</h2> <hr> <h3 id="store-state-count">{{$store.state.count}}</h3> </template> <script> import store from '@/vuex/store' export default{ data(){ return{ msg:'Hello Vuex', } }, store } </script>
ここでのミューテーションは固定された方法で書かれており、変更できることを意味します。そのため心配する必要はありません。state の値を変更したい方法はミューテーションで記述する必要があることだけを知っておいてください。
5. count.vue テンプレートに 2 つのボタンを追加し、ミューテーションでメソッドを呼び出します。
const mutations={ add(state){ state.count+=1; }, reduce(state){ state.count-=1; } }
このようにプレビューすることで、vuex上でカウントを加算したり減算したりすることができます。 {{$store.state.count}}
输出count 的值。
<p> <button>+</button> <button>-</button> </p>
4、在store.js文件中加入两个改变state的方法。
computed:{ count(){ return this.$store.state.count; } }
这里的mutations是固定的写法,意思是改变的,所以你先不用着急,只知道我们要改变state的数值的方法,必须写在mutations里就可以了。
5、在count.vue模板中加入两个按钮,并调用mutations中的方法。
import {mapState} from 'vuex';
这样进行预览就可以实现对vuex中的count进行加减了。
state访问状态对象
const state ,这个就是我们说的访问状态对象,它就是我们SPA(单页应用程序)中的共享值。
学习状态对象赋值给内部对象,也就是把stroe.js中的值,赋值给我们模板里data中的值。有三种赋值方式
一、 通过computed的计算属性直接赋值
computed属性可以在输出前,对data中的值进行改变,我们就利用这种特性把store.js中的state值赋值给我们模板中的data值。
computed:mapState({ count:state=>state.count //理解为传入state对象,修改state.count属性 })
这里需要注意的是return this.$store.state.count
state アクセス状態オブジェクト
const state 、これはアクセス状態オブジェクトと呼ばれるもので、SPA (シングル ページ アプリケーション) の共有値です。 学習ステータス オブジェクトを内部オブジェクトに割り当てます。つまり、strobe.js の値をテンプレートのデータの値に割り当てます。割り当て方法は 3 つあります 1. 計算された計算属性による直接割り当て計算された属性は、出力前にデータ内の値を変更できます。この機能を使用して、store.js の状態値を変更します。テンプレート内のデータ値。
computed:mapState(["count"])ここで注意する必要があるのは、
return this.$store.state.count
という文です。これを必ず書いてください。そうしないと、$store が見つかりません。この書き方はわかりやすいですが、書くのが面倒です。 2番目の書き方を見てみましょう。
2.mapState オブジェクトを通じて値を割り当てます
まず import を使用して、mapState を導入する必要があります。 🎜Mutations修改状态($store.commit( ))🎜次に、計算されたプロパティに次のコードを記述します: 🎜
<button>+</button> <button>-</button>🎜 ここでは、ES6 のアロー関数を使用してカウントする値を割り当てます。 🎜🎜🎜🎜3.mapState配列で値を代入する🎜🎜🎜
const mutations={ add(state){ state.count+=1; }, reduce(state){ state.count-=1; } }🎜 これが最も簡単な書き方で、実際のプロジェクト開発ではよく使われます。 🎜
const mutations={ add(state,n){ state.count+=n; }, reduce(state){ state.count-=1; } }🎜Vuex には、状態を変更するための commit メソッドが用意されています。デモのサンプル コードの内容を貼り付け、ボタンの変更方法を簡単に確認します。 🎜
<p> <button>+</button> <button>-</button> </p>🎜store.js ファイル: 🎜
import { mapState,mapMutations } from 'vuex';🎜 値の受け渡し: これは状態を変更するための最も単純な操作です。実際のプロジェクトでは、状態を変更するときに値を渡す必要があることがよくあります。たとえば、上記の例では毎回 1 を追加するだけですが、今度は渡された値を追加する必要があります。実際には、Mutations に別のパラメータを追加し、コミット時にそれを渡すだけで済みます。具体的なコードを見てみましょう: 🎜
现在store.js文件里给add方法加上一个参数n。
const mutations={ add(state,n){ state.count+=n; }, reduce(state){ state.count-=1; } }
在Count.vue里修改按钮的commit( )方法传递的参数,我们传递10,意思就是每次加10.
<p> <button>+</button> <button>-</button> </p>
模板获取Mutations方法
实际开发中我们也不喜欢看到$store.commit( )这样的方法出现,我们希望跟调用模板里的方法一样调用。
例如:@click=”reduce” 就和没引用vuex插件一样。要达到这种写法,只需要简单的两部就可以了:
1、在模板count.vue里用import 引入我们的mapMutations:
import { mapState,mapMutations } from 'vuex';
2、在模板的标签里添加methods属性,并加入mapMutations
methods:mapMutations([ 'add','reduce' ]),
通过上边两部,我们已经可以在模板中直接使用我们的reduce或者add方法了,就像下面这样。
<button>-</button>
getters计算过滤操作
getters从表面是获得的意思,可以把他看作在获取数据之前进行的一种再编辑,相当于对数据的一个过滤和加工。你可以把它看作store.js的计算属性。
getters基本用法:
比如我们现在要对store.js文件中的count进行一个计算属性的操作,就是在它输出前,给它加上100.我们首先要在store.js里用const声明我们的getters属性。
const getters = { count:function(state){ return state.count +=100; } }
写好了gettters之后,我们还需要在Vuex.Store()里引入,由于之前我们已经引入了state和mutations,所以引入里有三个引入属性。代码如下,
export default new Vuex.Store({ state,mutations,getters })
在store.js里的配置算是完成了,我们需要到模板页对computed进行配置。在vue 的构造器里边只能有一个computed属性,如果你写多个,只有最后一个computed属性可用,所以要对上节课写的computed属性进行一个改造。改造时我们使用ES6中的展开运算符”…”。
computed:{ ...mapState(["count"]), count(){ return this.$store.getters.count; } },
需要注意的是,你写了这个配置后,在每次count 的值发生变化的时候,都会进行加100的操作。
用mapGetters简化模板写法
我们都知道state和mutations都有map的引用方法把我们模板中的编码进行简化,我们的getters也是有的,我们来看一下代码。
首先用import引入我们的mapGetters
import { mapState,mapMutations,mapGetters } from 'vuex';
在computed属性中加入mapGetters
...mapGetters(["count"])
actions异步修改状态
actions和之前讲的Mutations功能基本一样,不同点是,actions是异步的改变state状态,而Mutations是同步改变状态。至于什么是异步什么是同步这里我就不做太多解释了,如果你不懂自己去百度查一下吧。
在store.js中声明actions
actions是可以调用Mutations里的方法的,我们还是继续在上节课的代码基础上进行学习,在actions里调用add和reduce两个方法。
const actions ={ addAction(context){ context.commit('add',10) }, reduceAction({commit}){ commit('reduce') } }
在actions里写了两个方法addAction和reduceAction,在方法体里,我们都用commit调用了Mutations里边的方法。细心的小伙伴会发现这两个方法传递的参数也不一样。
•ontext:上下文对象,这里你可以理解称store本身。
•{commit}:直接把commit对象传递过来,可以让方法体逻辑和代码更清晰明了。
模板中的使用
我们需要在count.vue模板中编写代码,让actions生效。我们先复制两个以前有的按钮,并改成我们的actions里的方法名,分别是:addAction和reduceAction。
<button>-</button>
改造一下我们的methods方法,首先还是用扩展运算符把mapMutations和mapActions加入。
methods:{ ...mapMutations([ 'add','reduce' ]), ...mapActions(['addAction','reduceAction']) },
你还要记得用import把我们的mapActions引入才可以使用。
增加异步检验
我们现在看的效果和我们用Mutations作的一模一样,肯定有的小伙伴会好奇,那actions有什么用,我们为了演示actions的异步功能,我们增加一个计时器(setTimeOut)延迟执行。在addAction里使用setTimeOut进行延迟执行。
setTimeOut(()=>{context.commit(reduce)},3000); console.log('我比reduce提前执行');
我们可以看到在控制台先打印出了‘我比reduce提前执行'这句话。
module模块组
随着项目的复杂性增加,我们共享的状态越来越多,这时候我们就需要把我们状态的各种操作进行一个分组,分组后再进行按组编写。那今天我们就学习一下module:状态管理器的模块组操作。
声明模块组:
在vuex/store.js中声明模块组,我们还是用我们的const常量的方法声明模块组。代码如下:
const moduleA={ state,mutations,getters,actions }
声明好后,我们需要修改原来 Vuex.Stroe里的值:
export default new Vuex.Store({ modules:{a:moduleA} })
在模板中使用
现在我们要在模板中使用count状态,要用插值的形式写入。
<h3 id="store-state-a-count">{{$store.state.a.count}}</h3>
如果想用简单的方法引入,还是要在我们的计算属性中rutrun我们的状态。写法如下:
computed:{ count(){ return this.$store.state.a.count; } },
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上がゼロからの Vuexの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。

Pythonは、スムーズな学習曲線と簡潔な構文を備えた初心者により適しています。 JavaScriptは、急な学習曲線と柔軟な構文を備えたフロントエンド開発に適しています。 1。Python構文は直感的で、データサイエンスやバックエンド開発に適しています。 2。JavaScriptは柔軟で、フロントエンドおよびサーバー側のプログラミングで広く使用されています。

PythonとJavaScriptには、コミュニティ、ライブラリ、リソースの観点から、独自の利点と短所があります。 1)Pythonコミュニティはフレンドリーで初心者に適していますが、フロントエンドの開発リソースはJavaScriptほど豊富ではありません。 2)Pythonはデータサイエンスおよび機械学習ライブラリで強力ですが、JavaScriptはフロントエンド開発ライブラリとフレームワークで優れています。 3)どちらも豊富な学習リソースを持っていますが、Pythonは公式文書から始めるのに適していますが、JavaScriptはMDNWebDocsにより優れています。選択は、プロジェクトのニーズと個人的な関心に基づいている必要があります。

C/CからJavaScriptへのシフトには、動的なタイピング、ゴミ収集、非同期プログラミングへの適応が必要です。 1)C/Cは、手動メモリ管理を必要とする静的に型付けられた言語であり、JavaScriptは動的に型付けされ、ごみ収集が自動的に処理されます。 2)C/Cはマシンコードにコンパイルする必要がありますが、JavaScriptは解釈言語です。 3)JavaScriptは、閉鎖、プロトタイプチェーン、約束などの概念を導入します。これにより、柔軟性と非同期プログラミング機能が向上します。

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SAP NetWeaver Server Adapter for Eclipse
Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

Dreamweaver Mac版
ビジュアル Web 開発ツール
