您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 15474|回复: 0
打印 上一主题 下一主题

[Vue.js] Vue.js 表单

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-4 11:22:23 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
这节我们为大家介绍 Vue.js 表单上的应用。
你可以用 v-model 指令在表单控件元素上创建双向数据绑定。
v-model 会根据控件类型自动选取正确的方法来更新元素。
输入框
实例中演示了 input 和 textarea 元素中使用 v-model 实现双向数据绑定:

; C" \5 N& Q( ^6 ]4 h. m
  1. <div id="app">- ?! p0 x; ^- L  c2 }
  2.   <p>input 元素:</p>2 ?0 Q1 W6 a/ Y
  3.   <input v-model="message" placeholder="编辑我……">' Q" x0 v% g+ D" y8 X6 q& E
  4.   <p>消息是: {{ message }}</p>
    # {$ E* d& w$ K
  5.    
    ' }$ K; F+ T1 ^, U! L
  6.   <p>textarea 元素:</p>  \4 V: d6 e5 C0 [$ t* b: L. e# c
  7.   <p style="white-space: pre">{{ message2 }}</p>9 [, S2 z  {7 Q9 ]. U' q7 m
  8.   <textarea v-model="message2" placeholder="多行文本输入……"></textarea>
    ) @+ s: Z% v) i1 @
  9. </div>) D$ |% U  m% a  _. o$ W( g3 w6 ~

  10. ) I% B; W$ g0 D. E! c
  11. <script>; d" B& }0 ~7 Q5 `, r- C
  12. new Vue({/ n  J" ?1 Q$ U4 \
  13.   el: '#app',$ K6 y/ G/ m8 @) ]) `6 A5 S% R$ ?
  14.   data: {$ p0 N& g# @1 y' i* D
  15.     message: 'Runoob',2 \& O/ {' C: V0 c6 f( A4 P
  16.     message2: '菜鸟教程\r\nhttp://www.runoob.com'
    , c5 L) i" r6 H" R  O* b
  17.   }  o! {% }8 v9 r; W: n
  18. })
    " o4 k/ X# \' j$ E  j6 m
  19. </script>
复制代码
复选框
复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组:
复选框
以下实例中演示了复选框的双向数据绑定:
; }( ~. j( J# d( d! m7 k
  1. <div id="app">1 T, F' G# s& ^& I6 T  K
  2.   <p>单个复选框:</p>
    4 d+ ]& E. t/ R' m7 }
  3.   <input type="checkbox" id="checkbox" v-model="checked">
    ; `6 Y- r: ^7 o' s) I0 b+ x3 N
  4.   <label for="checkbox">{{ checked }}</label>
    3 H/ n5 o0 y( @( W" L. x* P
  5.    
    2 f4 L) L5 k3 [
  6.   <p>多个复选框:</p>$ e- C$ X6 |7 \1 x: O% }
  7.   <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">
    2 N: B6 @' B& h
  8.   <label for="runoob">Runoob</label>
    1 m. B: a; z; [5 {
  9.   <input type="checkbox" id="google" value="Google" v-model="checkedNames">
    9 v4 P7 q# ^* j' o/ F: B2 i
  10.   <label for="google">Google</label>
    ; a# t9 L3 T* y: Y, T0 f
  11.   <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">
    ' A# w6 l! k. H  U! z
  12.   <label for="taobao">taobao</label>! z( d8 W7 B- c" ~
  13.   <br>  n* T1 n: \, i" ^' ?$ r
  14.   <span>选择的值为: {{ checkedNames }}</span>
    + S+ L2 l1 b9 C. I9 F
  15. </div>
    - d  Z8 p2 m1 [# c
  16. ) I1 u! d' b3 t/ F7 m
  17. <script>
      X' A$ a( Z/ M  }
  18. new Vue({
    5 W5 p8 S3 J4 m; p0 e" ]
  19.   el: '#app',# n5 F5 I- G: D0 U
  20.   data: {
    - t  ^- z: U* n# M4 p! H9 M
  21.     checked : false,
    ( l- O- U: G7 x8 J7 e
  22.     checkedNames: []
    / m2 Z1 g8 U+ f% W: M" M
  23.   }4 G. u. F% W1 s" A
  24. })! l( Y5 Q/ N* e  G2 {9 _' U
  25. </script>
复制代码
实例中勾选复选框效果如下所示:
单选按钮
以下实例中演示了单选按钮的双向数据绑定:
单选按钮% D3 G( c. `& R) q' H9 H
  1. <div id="app">' a1 _, G' D1 t9 l2 ~+ ?% B9 H
  2.   <input type="radio" id="runoob" value="Runoob" v-model="picked">
    5 h- I3 L8 |: y; S
  3.   <label for="runoob">Runoob</label>
    - a6 q$ ^1 n/ u, \8 m" Z
  4.   <br>
    # J- k% D6 \+ E: F' s" w
  5.   <input type="radio" id="google" value="Google" v-model="picked">& g8 V) g( h* i" s
  6.   <label for="google">Google</label>8 K+ k1 s3 P# S3 U; F
  7.   <br>$ J1 L3 C4 ~# j, n% ]: z8 j4 T
  8.   <span>选中值为: {{ picked }}</span>+ ^8 S& v% H+ y1 T  M
  9. </div>
    ' ~" r: x2 g3 x* s' X

  10. 3 R+ ]7 R* D5 ~* A
  11. <script>
    0 p* ?( e5 c0 ]% i1 h; Q; i& ?
  12. new Vue({. Z& {8 B" J: k9 r$ P5 O  M3 {/ h
  13.   el: '#app',9 |* M, e2 f" `& v" Q% i
  14.   data: {  B5 W" K6 k: q) f' a
  15.     picked : 'Runoob'
    + s: O% v* [: h6 o. _
  16.   }
    8 a" ^* f. w  g4 A$ {
  17. })
    1 A; ^6 d& G( M: Y" P( H$ g% W  g
  18. </script>
复制代码
选中后,效果如下图所示:
select 列表
以下实例中演示了下拉列表的双向数据绑定:
select2 J" V5 m/ x8 y% K
  1. <div id="app">7 m+ W: V( z8 O6 _
  2.   <select v-model="selected" name="fruit"># E! Y2 s8 Y. \" r, g
  3.     <option value="">选择一个网站</option>
    1 Y( T& Z0 \" U. J
  4.     <option value="www.runoob.com">Runoob</option>
    - v( n; E) X6 b
  5.     <option value="www.google.com">Google</option>
    + ?% D8 C8 x+ L* ?& B
  6.   </select>* y+ I( g# I. F. N. _
  7. 5 K8 c' e$ P$ p. ]: ?1 s0 ?2 Y% E
  8.   <div id="output">' I8 F1 _" R# V; u3 r' f- j
  9.       选择的网站是: {{selected}}
    ' V/ O2 ~& }5 E! n/ i3 x
  10.   </div>5 S9 O0 `" T$ {" H% e+ J  \
  11. </div>0 v" v& |* L5 v$ O$ @+ a8 }6 `( B

  12. 5 z  M4 O/ C. L% ?. @  j: s
  13. <script>7 C: |( }  U0 I  E, ]
  14. new Vue({
    4 [8 [2 `" z0 b4 v
  15.   el: '#app',
    ; Z# Y; a$ W6 W8 a1 M
  16.   data: {; K7 z3 Y# k2 \/ W) l
  17.     selected: ''
    , p+ u( _2 h( ?0 \
  18.   }
    ' k& K7 e1 q; n' ^( d
  19. })' s% B1 a3 O1 c! {, X! [; k
  20. </script>
复制代码
选取 cncml,输出效果如下所示:
修饰符.lazy
在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步:
  1. <!-- 在 "change" 而不是 "input" 事件中更新 -->
    2 e; n4 Z/ w& g! z! F' a1 @8 B
  2. <input v-model.lazy="msg" >
复制代码
.number
如果想自动将用户的输入值转为 Number 类型(如果原值的转换结果为 NaN 则返回原值),可以添加一个修饰符 number 给 v-model 来处理输入值:
  1. <input v-model.number="age" type="number">
复制代码
这通常很有用,因为在 type="number" 时 HTML 中输入的值也总是会返回字符串类型。
.trim
如果要自动过滤用户输入的首尾空格,可以添加 trim 修饰符到 v-model 上过滤输入:
  1. <input v-model.trim="msg">
复制代码
全选与取消全选
  1. new Vue({
    4 [& J& n/ B0 P: ^, B; F' n3 g
  2.     el: '#app',
    / k% i9 }" ~) Z. a- F
  3.     data: {  c: O4 h* a4 x9 y, T9 ?
  4.         checked: false,) E* B- q) o; w" O- T
  5.         checkedNames: [],
    ' u+ o! f! i' V# D/ z7 C
  6.         checkedArr: ["Runoob", "Taobao", "Google"]
    ) A+ k# Y3 H; ?: ~: l7 y
  7.     },
    ! ]2 G" ^' b' w# A
  8.     methods: {( _  F& z5 L5 f: ~( W9 v3 y; Y
  9.         changeAllChecked: function() {- w1 y" m7 k+ D$ T# D
  10.             if (this.checked) {6 G  S; K) o, N7 X5 |
  11.                 this.checkedNames = this.checkedArr% a8 @6 h+ y) \( g9 D5 A& k8 t
  12.             } else {; p7 G5 F" Q, i4 W% Y$ i' v- a
  13.                 this.checkedNames = []) z  t7 A5 ?: D8 U
  14.             }
    3 u# {5 Q9 a" ]' k' W) P2 d/ h
  15.         }
    : Q7 A- M' z1 H
  16.     },
    7 r' Q( C" i+ a7 z( e
  17.     watch: {" @9 j4 R4 x" F2 {0 [
  18.         "checkedNames": function() {
    / _, p" U4 L: L+ p9 I7 q
  19.             if (this.checkedNames.length == this.checkedArr.length) {
    ! i5 A- I' G' Y6 C) S4 [
  20.                 this.checked = true
    & L/ @3 a! d) X7 @* U
  21.             } else {
    ' {" g: u1 U$ G( C; X/ ^
  22.                 this.checked = false
    " M' G. l: I2 [; L  b8 a' s- q
  23.             }
    & N: {% Z/ }8 \! w" R: m; d: X( q
  24.         }
    1 R' I/ g" \  z& V. q: U) ?8 T! K
  25.     }% G4 J; N' U, F! `* r. k( r6 k
  26. })
复制代码

. |. d, _9 q: _8 z; M; \7 g( L5 t7 z

- s% V  z) o- N5 u2 h3 d7 ?( a! A& u) h& E' `1 c/ i$ `6 b

1 C: f" ~+ O6 B8 S  b* ?# {  k; _: x) K" `: H
  E8 G% _- \) g% k8 j5 m

1 u- ?3 L3 R8 o4 ^
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-4-30 19:04 , Processed in 0.058142 second(s), 24 queries .

Copyright © 2001-2026 Powered by cncml! X3.2. Theme By cncml!