vue は prop の値を変更できますか?
vue の prop の値を直接変更することはできません。vue を直接変更すると、警告が生成され、プロパティ値を変更しても親コンポーネントに対応する変数を変更できません。ただし、子コンポーネントのイベントと親コンポーネントのリッスン このイベントは、親コンポーネントを変更する関数を実行し、子コンポーネントのイベントをリッスンして prop の値を変更することで双方向のデータ バインディングを実現します。
このチュートリアルの動作環境: Windows 10 システム、Vue3 バージョン、Dell G3 コンピューター。
vue は prop の値を変更できます
Vue では、prop は親コンポーネントから子コンポーネントに渡される属性を受け入れることができますが、prop を変更することはできません。
プロップが強制的に変更されると、警告が表示されます
すべてのプロップは、親プロップと子プロップの間に一方向の下向きバインディングを形成します: 親プロップの更新により、下向きにサブコンポーネントに流れますが、その逆はありません。これにより、子コンポーネントが親コンポーネントの状態を誤って変更して、アプリケーションのデータ フローが理解しにくくなるのを防ぐことができます。
さらに、親コンポーネントが変更されるたびに、子コンポーネント内のすべてのプロパティが最新の値に更新されます。これは、子コンポーネント内の props を変更すべきではないことを意味します。これを行うと、Vue はブラウザーのコンソールに警告を発行します。 次の方法で属性値を直接変更してみてくださいthis.$props.modelValue = true;
キー「modelValue」の設定操作が失敗しました: ターゲットは読み取り専用です.また、この属性の値を変更しても、親コンポーネントに対応する変数を変更することはできません。これは、基本データ型にのみ適用されます。 JavaScript では、オブジェクトと配列は参照によって渡されるため、配列またはオブジェクト型プロパティの場合、
子コンポーネント内のオブジェクトまたは配列自体を変更すると、親コンポーネントの状態に影響を与えることに注意してください。また、Vue はそれについて # 警告することはできません。原則として、オブジェクトや配列を含むプロパティの変更は避けてください。変更すると一方向のデータ バインディングが無視され、予期しない結果が生じる可能性があります。
Vue3 Props Document正しい変更方法は、子コンポーネント イベントをトリガーすることです。親コンポーネントはイベントをリッスンし、親コンポーネントを変更する関数を実行します。例として、model を使用します。v-model
自体は、子コンポーネントに渡される modelValue
属性であり、update:modelValue
イベントをリッスンします。 双方向データ バインディング
を実現するため、このメソッドを使用して modelValue<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">this.$emit("update:modelValue", !this.$props.modelValue);</pre><div class="contentsignin">ログイン後にコピー</div></div>
を変更することもできます。これは自動的にリッスンします。 update:modelValue
イベント そして、modelValue
を、イベントのトリガー時に渡されるパラメーター値 (つまり、$emit の 2 番目のパラメーター) に変更します。 イベントのトリガーとイベントの監視のこのデータ フロー モードは、すぐには有効になりません。次のコード
this.$emit("update:modelValue", !this.$props.modelValue);console.log(this.$props.modelValue);
を使用すると、コンソールへの出力がわかります。
modelValue は、トリガー イベント - リッスン イベント モードで属性値を変更するのに時間がかかるため、元の値のままですが、代わりに次のコードを使用すると、出力が正常であることがわかります: <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">this.$emit("update:modelValue", !this.$props.modelValue);setTimeout(()=> {console.log(this.$props.modelValue)}, 1000)</pre><div class="contentsignin">ログイン後にコピー</div></div>
Practice
Vant は左側に
label の入力ボックスしか実装していないので、右側に label
の入力ボックスを実装したいと思います。この Vant3 フィールド ドキュメント
に基づいて、ここで発生する問題は、
label を右に移動し、 の内容に従って幅を調整することに加えて、 label
、Vant の <van-field />## です
# と親の間のデータ フローを実装する必要があります
が配置されるコンポーネント。
間違い
v-model
を と一貫して使用できるようにするために、私は
< を実行しました。 right-label-input /> の下に
modelValue 属性を設定し、次に
v-model="modelValue"
を設定します。 #<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><template>
<van-field :placeholder="placeholder" :name="name" v-model="modelValue" :disabled="disabled"/>
</template>
<script>
export default {
name: "RightLabelInput",
props: {
modelValue: "",
},
}
</script></pre><div class="contentsignin">ログイン後にコピー</div></div>
間違いなく、このアプローチは一方向データ フローの原則に違反します。VanField
が変更されると、
modelValue 値に直接影響します。 RightLabelInput
。modelValue
は RightLabelInput
のプロパティであり、直接変更することはできません。 おそらく正しいアプローチ
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><template>
<van-field :placeholder="placeholder"
:name="name"
v-model="input"
:disabled="disabled"
/>
</template>
<script>
export default {
name: "RightLabelInput",
props: {
placeholder: "",
name: "",
label: "",
modelValue: "",
disabled: {
type: Boolean,
default: false
}
},
data() {
return {
input: this.modelValue, // 绑定到 data 的变量,防止直接修改 Props
}
},
beforeMount() {
this.input = this.modelValue
},
watch: {
input(newInput, oldInput) {
this.$emit("update:modelValue", newInput); // 监听 input 在修改时发起事件,由父组件修改 modelValue 的值
},
modelValue(newValue, oldValue) {
this.input = newValue;
}
}
}
</script>
<style scoped>
</style></pre><div class="contentsignin">ログイン後にコピー</div></div>
: 一方向のデータ フロー
[関連する推奨事項: 「vue.js チュートリアル##」 #》]
以上がvue は prop の値を変更できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Vue で ECharts を使用すると、アプリケーションにデータ視覚化機能を簡単に追加できます。具体的な手順には、ECharts および Vue ECharts パッケージのインストール、ECharts の導入、チャート コンポーネントの作成、オプションの構成、チャート コンポーネントの使用、Vue データに対応したチャートの作成、対話型機能の追加、および高度な使用法の使用が含まれます。

質問: Vue におけるエクスポートのデフォルトの役割は何ですか?詳細説明: エクスポートデフォルトは、コンポーネントのデフォルトのエクスポートを定義します。インポートすると、コンポーネントが自動的にインポートされます。インポートプロセスを簡素化し、明確さを改善し、競合を防ぎます。一般に、名前付きエクスポートとデフォルト エクスポートの両方を使用して、個々のコンポーネントをエクスポートし、グローバル コンポーネントを登録するために使用されます。

Vue.js マップ関数は、各要素が元の配列の各要素の変換結果である新しい配列を作成する組み込みの高階関数です。構文は、map(callbackFn) です。callbackFn は、配列内の各要素を最初の引数として受け取り、オプションでインデックスを 2 番目の引数として受け取り、値を返します。 map 関数は元の配列を変更しません。

Vue.js では、event はブラウザによってトリガーされるネイティブ JavaScript イベントですが、$event は Vue コンポーネントで使用される Vue 固有の抽象イベント オブジェクトです。 $event はデータ バインディングをサポートするようにフォーマットおよび拡張されているため、一般に $event を使用する方が便利です。ネイティブ イベント オブジェクトの特定の機能にアクセスする必要がある場合は、event を使用します。

Vue.js でモジュールをエクスポートするには、エクスポートとデフォルトのエクスポートの 2 つの方法があります。 export は名前付きエンティティのエクスポートに使用され、中括弧の使用が必要です。export default はデフォルト エンティティのエクスポートに使用され、中括弧は必要ありません。インポートする場合、エクスポートによってエクスポートされたエンティティはその名前を使用する必要がありますが、エクスポートのデフォルトによってエクスポートされたエンティティは暗黙的に使用できます。複数回インポートする必要があるモジュールにはデフォルトのエクスポートを使用し、一度だけエクスポートするモジュールにはエクスポートを使用することをお勧めします。

onMounted は、Vue のコンポーネント マウント ライフ サイクル フックです。その機能は、コンポーネントが DOM にマウントされた後に、DOM 要素への参照の取得、データの設定、HTTP リクエストの送信、イベント リスナーの登録などの初期化操作を実行することです。コンポーネントが更新された後、またはコンポーネントが破棄される前に操作を実行する必要がある場合は、他のライフサイクル フックを使用できます。

Vue フックは、特定のイベントまたはライフサイクル ステージでアクションを実行するコールバック関数です。これらには、ライフサイクル フック (beforeCreate、mounted、beforeDestroy など)、イベント処理フック (クリック、入力、キーダウンなど)、およびカスタム フックが含まれます。フックはコンポーネントの制御を強化し、コンポーネントのライフサイクルに対応し、ユーザーの操作を処理し、コンポーネントの再利用性を向上させます。フックを使用するには、フック関数を定義し、ロジックを実行してオプションの値を返すだけです。

Vue.js イベント修飾子は、次のような特定の動作を追加するために使用されます。 デフォルト動作の防止 (.prevent) イベント バブリングの停止 (.stop) ワンタイム イベント (.once) イベントのキャプチャ (.capture) パッシブ イベント リスニング (.passive) アダプティブ修飾子 (.self)キー修飾子 (.key)
