vue3でのv-modelの使い方
単一の属性をバインドする
基本的なバインディング
コンポーネントをカスタマイズするには CustomInput
例
<script setup> const txt = ref(''); </script> <template> <CustomInput v-model="txt" /> </template>
v-model
それ
<CustomInput :modelValue="txt" @update:modelValue="newValue => txt = newValue" />
<CustomInput>
コンポーネント内で 2 つのことを行う必要があります:
内部ネイティブを変換します。
<input>
ネイティブ ## の場合、要素のvalue
属性はmodelValue
prop# にバインドされます。 #input
イベントがトリガーされると、新しい値を運ぶ
update:modelValueカスタム イベントがトリガーされます
<script setup> const props = defineProps({ 'modelValue': String, }) const emit = defineEmits(["update:modelValue"]) </script> <template> <input :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" /> </template>
v-model を実装する別の方法は次のとおりです。 getter と setter の
computed 属性
computed 属性を使用する場合、
get メソッドは
modelValue prop を返す必要があり、
set メソッドは対応するイベントをトリガーする必要があります
<script setup> const value = computed({ get() { return props.modelValue }, set(value) { emit("update:modelValue", value) } }) </script> <template> <input v-model="value" /> </template>
v-model 簡単に実行できますが、複数の属性に双方向のバインディングが必要な場合はどうすればよいですか?
v-model はコンポーネントの prop として
modelValue を使用し、コンポーネントの prop として
update:modelValue を使用します。対応するイベント
v -model を渡すこともできます。 これらの名前を変更するパラメーターを指定します。
<template> <CustomInput v-model:first-name="first" v-model:last-name="last" /> </template>
prop は元の
modelValue から変更され、渡されたパラメータ名に変更され、対応するイベントも
update: パラメータ名
<script setup> const props = defineProps({ firstName: String, lastName: String, }) // 在computed中 使用 const emit = defineEmits(['update:firstName', 'update:lastName']) </script> <template> <input type="text" :value="firstName" @input="$emit('update:firstName', $event.target.value)" /> <input type="text" :value="lastName" @input="$emit('update:lastName', $event.target.value)" /> </template>
searchBar 複雑なフォーム コンポーネントの場合
<script setup> import { ref } from "vue" const modelValue = ref({ keyword: "123", selectValue: "", options: [ { label: "全部", value: "" }, { label: "a1", value: "1" }, { label: "a2", value: "2" }, ] }) </script> <template> <searchBar v-model="modelValue" /> </template>
searchBar コンポーネントで ## を受け取ります#modelValue
を指定し、タイプを Object
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'><template>
<div>
<!-- <input type="text" v-model="modelValue.keyword"> 可以实现双向绑定 -->
<input type="text"
:value="modelValue.keyword"
@input="handleKeywordChange"
>
<select v-model="modelValue.selectValue">
<option v-for="o in modelValue.options" :key="o.value" :value="o.value">
{{ o.label }}
</option>
</select>
</div>
</template>
<script lang="ts" setup>
const props = defineProps({
modelValue: {
type: Object,
default: () => ({})
}
})
const emit = defineEmits(["update:modelValue"]);
// 以 input 举例
const handleKeywordChange=(val)=>{
emit("update:modelValue",{
...props.modelValue,
keyword:val.target.value
})
}
</script></pre><div class="contentsignin">ログイン後にコピー</div></div># として定義します。
##コメントに記載されているように、オブジェクトが渡された場合は、
これは両方向のバインディングで直接実行できますが、これにより
トリガー イベントと同じですが、渡されたデータはオブジェクトになります
単一のデータ フローが破壊されます# # 上記の emit
emit を使用すると双方向バインディングをトリガーできますが、あまりにも煩雑です。奇抜なスキルとも言える書き方 -- computed prxoy
computed バインディングを使用する場合は、次のように記述できます。このコード
<template> <input type="text" v-model="model.keyword"> </template> <script lang="ts" setup> const model = computed({ get() { return props.modelValue }, set(value) { // console.log(value) // 发现没有打印 emit("update:modelValue", { ...props.modelValue, keyword: value }) } }) <script>
しかし、入力すると setter
がトリガーされないことがわかります。
はプロキシのレイヤーであり、プロキシ オブジェクトはプロキシ オブジェクトではないためです。修正済み setter
をトリガーする場合は、以下のようにします。
// 只有这样才会变化 model.value = { keyword:"asdfad" }
このメソッドは setter
をトリガーできないため、双方向バインディングは実行できません。完了しました。どうすればよいでしょうか?
getter
で
getter
で proxy オブジェクトを返します! getter
で proxy オブジェクトを返します! プロキシ オブジェクトはプロキシされたオブジェクトのプロパティと一致しているため、proxy を使用して元のオブジェクトをラップします
その後、v-model
がプロキシの背後にあるオブジェクトにバインドされます。プロキシ オブジェクトのプロパティが変更されると、プロキシ オブジェクトの set
メソッドがトリガーされます。この時点で、
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class='brush:php;toolbar:false;'>const model = computed({
get() {
return new Proxy(props.modelValue, {
set(obj, name, val) {
emit("update:modelValue", {
...obj,
[name]: val
})
return true
}
})
},
set(value) {
emit("update:modelValue", {
...props.modelValue,
keyword: value
})
}
})</pre><div class="contentsignin">ログイン後にコピー</div></div>
Modifiersv-model
には、
.number
および.lazy。
一部のシナリオでは、カスタム コンポーネントの
v-model でカスタム修飾子をサポートすることが必要になる場合があります。
カスタム修飾子
capitalize
v-model バインディング入力の文字列値の最初の文字を自動的に大文字に変換します:
<CustomInput v-model.capitalize="txt" />
capitalize 修飾子を追加しました。これは、
prop中
<script setup> const props = defineProps({ modelValue: String, modelModifiers: { default: () => ({}) } }) const emitValue = (e) => { let value = e.target.value; // 使用 修饰符 if (props.modelModifiers.capitalize) { value = value.charAt(0).toUpperCase() + value.slice(1) } emit('update:modelValue', value) } </script> <template> <input :value="modelValue" @input="emitValue" /> </template>
modelModifiers に自動的に渡されます。
以上がvue3でのv-modelの使い方の詳細内容です。詳細については、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)

ホットトピック











vue3+vite:src は、イメージとエラー レポートと解決策を動的にインポートするために require を使用します。vue3+vite は複数のイメージを動的にインポートします。vue3。TypeScript 開発を使用している場合、イメージを導入するために require のエラー メッセージが表示されます。requireisnotdefined は使用できません。 vue2 のような imgUrl:require(' .../assets/test.png') は、typescript が require をサポートしていないため、インポートされます。そのため、import が使用されます。解決方法は次のとおりです: awaitimport を使用します

tinymce はフル機能のリッチ テキスト エディター プラグインですが、tinymce を vue に導入するのは他の Vue リッチ テキスト プラグインほどスムーズではありません。tinymce 自体は Vue には適しておらず、@tinymce/tinymce-vue を導入する必要があります。外国のリッチテキストプラグインであり、中国語版を通過していないため、公式 Web サイトから翻訳パッケージをダウンロードする必要があります (ファイアウォールをバイパスする必要がある場合があります)。 1. 関連する依存関係をインストールします npminstalltinymce-Snpminstall@tinymce/tinymce-vue-S2. 中国語パッケージをダウンロードします 3. スキンと中国語パッケージを導入します. プロジェクトのパブリック フォルダーに新しい tinymce フォルダーを作成し、

Vue はブログ フロントエンドを実装しており、マークダウン解析を実装する必要があり、コードがある場合はコードのハイライトを実装する必要があります。 Vue には、markdown-it、vue-markdown-loader、marked、vue-markdown など、マークダウン解析ライブラリが多数あります。これらのライブラリはすべて非常に似ています。ここではMarkedが使用され、コード強調表示ライブラリとしてhighlight.jsが使用されます。 1. 依存ライブラリをインストールする vue プロジェクトの下でコマンド ウィンドウを開き、次のコマンド npminstallmarked-save//marked を入力して、マークダウンを htmlnpmins に変換します。

ページの部分的な更新を実現するには、ローカル コンポーネント (dom) の再レンダリングを実装するだけで済みます。 Vue でこの効果を実現する最も簡単な方法は、v-if ディレクティブを使用することです。 Vue2 では、v-if 命令を使用してローカル dom を再レンダリングすることに加えて、新しい空のコンポーネントを作成することもできます。ローカル ページを更新する必要がある場合は、この空のコンポーネント ページにジャンプしてから、再びジャンプします。 beforeRouteEnter ガードを空白のコンポーネントに配置します。元のページ。以下の図に示すように、Vue3.X の更新ボタンをクリックして赤枠内の DOM を再読み込みし、対応する読み込みステータスを表示する方法を示します。 Vue3.X の scriptsetup 構文のコンポーネントのガードには o しかないので、

Vue では、v-model は双方向バインディングの実装に使用される重要な命令であり、ユーザー入力を Vue のデータ属性に簡単に同期できるようにします。ただし、ユーザーが入力した文字列型を数値型に変換するなど、データを変換する必要がある場合には、v-model の .number 修飾子を使用する必要があります。 v-model.number の基本的な使い方 v-model.number は v-model を修正したものです

はじめに vue であれ、react であれ、複数の繰り返しコードに遭遇した場合、ファイルを冗長なコードの束で埋めるのではなく、これらのコードを再利用する方法を考えます。実際、vue と React はどちらもコンポーネントを抽出することで再利用を実現できますが、小さなコードの断片に遭遇し、別のファイルを抽出したくない場合は、それに比べて、React は同じファイル内で対応するウィジェットを宣言して使用できます。または、次のような renderfunction を通じて実装します。 constDemo:FC=({msg})=>{returndemomsgis{msg}}constApp:FC=()=>{return(

Vue を使用してカスタム要素を構築する WebComponents は、開発者が再利用可能なカスタム要素 (カスタム要素) を作成できるようにする一連の Web ネイティブ API の総称です。カスタム要素の主な利点は、フレームワークがなくても、任意のフレームワークで使用できることです。これらは、異なるフロントエンド テクノロジ スタックを使用している可能性のあるエンド ユーザーをターゲットにする場合、または最終アプリケーションを使用するコンポーネントの実装の詳細から切り離したい場合に最適です。 Vue と WebComponents は補完的なテクノロジであり、Vue はカスタム要素の使用と作成に対する優れたサポートを提供します。カスタム要素を既存の Vue アプリケーションに統合したり、Vue を使用してビルドしたりできます。

1 はじめに 1.1 目的 ElementPlus は、パッケージ化されたファイルのサイズを大幅に削減するためにオンデマンド導入を使用します 1.2 最終効果は、components.d.ts ファイルを自動的に生成し、ファイルに導入します ElementPlus コンポーネントは、components.d を自動的に生成します。 ElementPlusAPI2 準備 ElementPlus をインストール#好きなパッケージ マネージャーを選択#NPM$npminstallelement-plus--save#Yarn$yarnaddelement-plus#pnpm$pnpminstallelement-plus3 を押します
