這篇文章要跟大家介紹的文章內容是關於Vue中v-model指令的分析(附程式碼),有很好的參考價值,希望可以幫助到有需要的朋友。
1. 指令釋義
v-model在表單控制項或元件上建立雙向綁定,本質上是負責監聽使用者的輸入事件(onchange,onkeyup,onkeydown等,具體是哪個,也請查閱官方底層實作文件)以更新數據,並對一些極端場景進行一些特殊處理。
2. 表單輸入綁定方式與方法
2.1 input框實作雙向資料綁定範例:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <label>请输入:</label><input type="text" v-model="inputs"/><br/> <label>你在input框中输入了:</label><span>{{inputs}}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', inputs: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
2.2 textarea多行文字實作雙想資料綁定範例:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <label>请输入:</label><textarea v-model="text"></textarea><br/> <label>你在textarea框中输入了:</label><span>{{text}}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', text: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
#2.3 複選框實作資料綁定
單一複選框資料綁定範例:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <label>请输入:</label><input type="checkbox" id="checkbox" v-model="checked">选我<br/> <label v-if="checked">选中了:</label> <label v-if="!checked">没选中:</label> <span>{{ checked }}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', checked: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
#多個複選框實作資料綁定範例:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <label>请输入:</label> <input type="checkbox" id="vue1" value="vue1" v-model="checkedValues">vue1 <input type="checkbox" id="vue2" value="vue2" v-model="checkedValues">vue2 <input type="checkbox" id="vue3" value="vue3" v-model="checkedValues">vue3 <br/> <label>选中了:</label><span>{{ checkedValues }}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', checkedValues: [] } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
#2.4 單選按鈕實作資料綁定,取得到選取的單選按鈕值顯示出來:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <input type="radio" id="radio1" value="1" v-model="checked">男<br/> <input type="radio" id="radio2" value="2" v-model="checked">女<br/> <label> 选中了:{{ checked }}</label> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', checked: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <select v-model="selected"> <option disabled value="">请选择</option> <option>A</option> <option value="2">B</option> <option value="3">C</option> </select> <span>Selected: {{ selected }}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', selected: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <select v-model="selected" multiple> <option disabled value="">请选择</option> <option>A</option> <option value="2">B</option> <option value="3">C</option> </select> <span>Selected: {{ selected }}</span> </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', selected: [] } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <!-- 在“change”时而非“input”时更新 --> <input type="text" id="names" v-model.lazy="msg" ><br/> <label>输入值:</label>{{msg}} </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', msg: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <!-- 在“change”时而非“input”时更新 --> <input type="number" id="names" v-model.number="msg" ><br/> <label>输入值:</label>{{msg}} </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', msg: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <label>无trim属性</label> <input type="text" id="names" v-model="msg1" ><br/> <label>输入值:</label>{{msg1}}<br/> <label>有trim属性</label> <input type="text" id="names2" v-model.trim="msg2" ><br/> <label>输入值:</label>{{msg2}} </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', msg1: '', msg2: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
4.1 自定义组件v-model
一个组件上的 v-model 默认会利用名为 value 的 prop 和名为 input 的事件,但是像输入框、单选框、复选框等类型的输入控件可能会将 value 特性用于不同的目的。本文以自定义输入框和onchange事件为例,在输入框输入值,当光标离开以后输入值会输出绑定到置顶位置:
1. 在index中声明组件(在index声明的组件为全局组件,全局可用):
Vue.component('base-text', { model: { prop: 'value', event: 'change' }, props: { checked: Boolean }, template: `<input>` }); =
2. 在要使用该组件的插件中声明:
<template> <div> <p class="p1">{{title}}</p> <div class="spancss1"> <base-text v-model="msg"></base-text><br/> <label>你输入了:</label>{{msg}} </div> </div> </template> <script> export default { name:"v-model", data(){ return { title: 'v-model学习', msg: '' } } } </script> <style scoped> .p1{ text-align: left; } .spancss1{ float: left; } </style>
3. 结果示例如下:
相关推荐:
以上是Vue中v-model指令的分析(附程式碼)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

本文討論了使用瀏覽器開發人員工具的有效JavaScript調試,專注於設置斷點,使用控制台和分析性能。

將矩陣電影特效帶入你的網頁!這是一個基於著名電影《黑客帝國》的酷炫jQuery插件。該插件模擬了電影中經典的綠色字符特效,只需選擇一張圖片,插件就會將其轉換為充滿數字字符的矩陣風格畫面。快來試試吧,非常有趣! 工作原理 插件將圖片加載到畫布上,讀取像素和顏色值: data = ctx.getImageData(x, y, settings.grainSize, settings.grainSize).data 插件巧妙地讀取圖片的矩形區域,並利用jQuery計算每個區域的平均顏色。然後,使用

本文將引導您使用jQuery庫創建一個簡單的圖片輪播。我們將使用bxSlider庫,它基於jQuery構建,並提供許多配置選項來設置輪播。 如今,圖片輪播已成為網站必備功能——一圖胜千言! 決定使用圖片輪播後,下一個問題是如何創建它。首先,您需要收集高質量、高分辨率的圖片。 接下來,您需要使用HTML和一些JavaScript代碼來創建圖片輪播。網絡上有很多庫可以幫助您以不同的方式創建輪播。我們將使用開源的bxSlider庫。 bxSlider庫支持響應式設計,因此使用此庫構建的輪播可以適應任何

數據集對於構建API模型和各種業務流程至關重要。這就是為什麼導入和導出CSV是經常需要的功能。在本教程中,您將學習如何在Angular中下載和導入CSV文件


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3漢化版
中文版,非常好用

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能