这节我们为大家介绍 Vue.js 表单上的应用。 你可以用 v-model 指令在表单控件元素上创建双向数据绑定。 v-model 会根据控件类型自动选取正确的方法来更新元素。 输入框实例中演示了 input 和 textarea 元素中使用 v-model 实现双向数据绑定:
9 K) h/ e1 |' P/ B" ^+ `- <div id="app">
! s! u) D( O, j3 I: G' X3 R- m - <p>input 元素:</p>
. b6 a+ o9 h" t - <input v-model="message" placeholder="编辑我……">& W3 M) L- [( h* e
- <p>消息是: {{ message }}</p>7 E" a8 v4 Q2 D& a% t# w
- $ q' @% t/ Y1 [# o. j. \( Z$ K
- <p>textarea 元素:</p>- |- d8 c. |3 @$ ~& j5 @% m/ p2 \& o
- <p style="white-space: pre">{{ message2 }}</p>
0 o! d3 Z1 w9 [" s; d - <textarea v-model="message2" placeholder="多行文本输入……"></textarea>
$ E) o' e `, p, w, t - </div>
/ V- ^- y9 Q4 u* h$ I" m1 E: p - + ~' |. s* F p
- <script>0 f: o5 m/ V$ j
- new Vue({
2 e% ?1 W! ]) ~/ n: p, _ - el: '#app', ] e( j8 J- G1 f7 }' `
- data: {
, H; C( b2 o! Z2 Y2 K) c# d - message: 'Runoob',
0 j; _6 a! v6 v9 U - message2: '菜鸟教程\r\nhttp://www.runoob.com'
2 K" n: q! z) D - }8 n2 ]$ q8 p4 W1 g" U3 T0 L, H
- })
" ~. K d' l; f& b% t - </script>
复制代码 复选框复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组: 复选框以下实例中演示了复选框的双向数据绑定: , K0 m7 K* q) F" c9 p
- <div id="app">; g$ o* f: z9 f1 [1 D
- <p>单个复选框:</p>+ F' q# v, y7 J1 }
- <input type="checkbox" id="checkbox" v-model="checked">
* `% H( G0 T/ W5 P/ {2 J - <label for="checkbox">{{ checked }}</label>1 `6 Z" j( I" B7 N8 S
-
) K5 }& z/ C) [8 q5 l - <p>多个复选框:</p>
$ s! V7 B% n- E1 v2 {2 Q - <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">
6 [- n+ M& I5 [' ^% e: e - <label for="runoob">Runoob</label>: F' Y9 B2 d4 e6 J4 E& R+ j; D
- <input type="checkbox" id="google" value="Google" v-model="checkedNames">, }+ o8 I% d+ k0 F5 V, j3 C& V
- <label for="google">Google</label>: u _' o; Q# U) f% T
- <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">- l, P$ h U& ~/ [3 h; {) x
- <label for="taobao">taobao</label>( _2 Y4 P& M2 Q$ A. k
- <br>* Y% K4 B+ `' X+ k2 y5 v
- <span>选择的值为: {{ checkedNames }}</span>
# h9 A: T+ g5 E9 v# ] - </div>8 g0 G: w! i% Z I. P8 U4 n
-
( ^: S* S9 }' P4 H" f9 m - <script>
9 T' B5 `) @1 Z4 @% ]! ` - new Vue({) f8 i2 v8 H. y' N
- el: '#app',: L0 F" {3 ~1 m- z q# k
- data: {7 b0 B" T/ o5 ]* X/ c- x/ @4 L$ s
- checked : false,) s V# Q; |4 X. B- d5 d, p3 [
- checkedNames: []$ b7 L8 L/ M2 C
- }
, G" p3 l1 B1 ?0 L- d - })8 c! v1 c) R. b, e
- </script>
复制代码实例中勾选复选框效果如下所示: 单选按钮以下实例中演示了单选按钮的双向数据绑定: 单选按钮
) Y _! a2 w( {- y- <div id="app">. H2 j4 Q/ C6 W r4 f
- <input type="radio" id="runoob" value="Runoob" v-model="picked">
% |' U8 r+ O0 n. n. o - <label for="runoob">Runoob</label>1 t. ?& J9 P- g, q# E, M+ G
- <br>
& f/ o; T% y! I- d, } - <input type="radio" id="google" value="Google" v-model="picked">& V6 G, j3 T. t, p4 G8 E. q6 R- P
- <label for="google">Google</label>1 ^9 C7 j+ F' C- c
- <br>6 I, [2 n' j {9 U8 y" q
- <span>选中值为: {{ picked }}</span>/ w+ y& S8 r+ X6 J' Z& c
- </div>
! ^6 |/ p& Y- i- R) I( I6 b# S. P* ? - 7 W$ D* v/ m! A6 ?7 c9 l
- <script>6 a6 g; `7 K+ I/ C0 s3 E: d
- new Vue({; m7 n. u' [5 _# N5 }: U" _! i6 n& h
- el: '#app',, Y4 i* E; ~$ C0 z
- data: {, l# d) D: R2 v* C4 m
- picked : 'Runoob'- K& A7 Q: U4 r1 n' Q* u5 M
- }
) {( c2 S8 V/ ]7 K$ F - })
# M/ u- H; b E7 G2 l - </script>
复制代码选中后,效果如下图所示: select 列表以下实例中演示了下拉列表的双向数据绑定: select: w# ^, x2 f% x( e# ]" X2 v5 Q
- <div id="app">
2 y# ~2 P4 Z( o0 T( X; O: G - <select v-model="selected" name="fruit">
% Y- o! @4 o9 B - <option value="">选择一个网站</option>* z! ]7 G% ~) x( S* g: g9 R
- <option value="www.runoob.com">Runoob</option>
( u C5 x2 ~! k3 L - <option value="www.google.com">Google</option>5 y7 S0 s: ~6 `. Y2 }, s
- </select>, U. J) e: T; y3 L4 _0 I9 ]
-
z( e: S$ P5 e - <div id="output">
0 ?2 h1 `/ B2 `5 Z; d. { - 选择的网站是: {{selected}}
/ h9 D- C- h. X) n6 J - </div>
& b5 j; j3 e& \ - </div>1 H# {' _& x F# y' C7 p
-
+ y" c8 e! A! o# S- P( H - <script>
# Q8 j4 f/ G Q9 ~1 _, w( b* E* b - new Vue({
3 I+ ]% k+ ^( A! F' g9 V - el: '#app',
# U$ Q( ]7 u' P - data: {) x5 V* A& x; {4 \
- selected: ''
9 t, z0 ^$ ?0 q( s+ Q6 `9 b) E+ M - }. T/ v5 I) v$ {, S1 y
- })
; v: B! |, a8 \( K - </script>
复制代码选取 cncml,输出效果如下所示: 修饰符.lazy在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步: - <!-- 在 "change" 而不是 "input" 事件中更新 -->; [4 r% u$ ]2 m" j
- <input v-model.lazy="msg" >
复制代码 .number如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值: - <input v-model.number="age" type="number">
复制代码这通常很有用,因为在 type="number" 时 HTML 中输入的值也总是会返回字符串类型。 .trim如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入: - <input v-model.trim="msg">
复制代码全选与取消全选 - new Vue({
* T. @. K' g2 B5 U& H - el: '#app',
! }+ Y+ n0 X6 b G - data: {3 e# g8 c0 m+ h& M2 S m% n+ |# ~
- checked: false,
2 E7 K, ^9 [ y" d+ ` - checkedNames: [],/ }# p7 U; b- }4 j( @' E
- checkedArr: ["Runoob", "Taobao", "Google"]
# t' p/ j" T* x1 _! P+ h A - },0 ?$ g0 m5 H B& ] L
- methods: {
& {) X+ ?0 c# L: |) K# o8 A- H- \ - changeAllChecked: function() {$ b& \/ v$ v- t: ~
- if (this.checked) {9 b/ f! p! F$ l d! N
- this.checkedNames = this.checkedArr
7 z$ b- m+ Q( p - } else {
. O$ j# q& Z& ]' a( [/ L - this.checkedNames = []
: a8 ^' \: K# p0 b$ Y( @ - }
7 ?* {0 W l5 C, W- O - }6 B" m6 F* a/ F
- },
7 F) D" ^ G; J+ ?9 g, `; A7 e - watch: {
4 O+ f" I% t$ J7 K! G, W - "checkedNames": function() {) x6 Z: D: V+ e9 ]7 o* J! s8 [
- if (this.checkedNames.length == this.checkedArr.length) {
3 L6 [) W& z7 d6 X; {/ S3 ?! e2 | - this.checked = true
- m+ A1 Q0 h, q( I - } else {
* U @8 G5 ]# X6 r - this.checked = false
1 W0 b, l$ o$ k5 @2 w - }: {6 I3 e6 A6 L* ?
- }: x$ d) R! N) Q% K. x4 R$ E" I6 Q9 ^" x
- }8 l' y6 S( }) d+ v: V" _
- })
复制代码
2 ?3 @" E( {$ i# A; `7 u3 W3 h1 u; |! k+ U$ U% v$ l8 H, B2 S
. t- J. R! K/ u) }' F, ~, C
' R) `( |: }$ E
# I; S3 B; p9 f& {
+ ]- z0 l# H: j0 ]4 T6 n8 D8 B x# ? D9 P( k
0 j, q: [1 \$ \4 s+ |+ O
|