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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 表单

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

7 e. s9 @  w( M: j! R$ H, w. \
  1. <div id="app">
    # _; L* A+ i1 L* F
  2.   <p>input 元素:</p>
      c$ v  {5 b1 N/ S8 ?
  3.   <input v-model="message" placeholder="编辑我……">/ C8 s1 H+ `- L
  4.   <p>消息是: {{ message }}</p>
    ; o9 |7 q" q) H+ Y( P/ |2 Z% x
  5.    
    8 s' H( Y8 [' Z* e8 a  K) C
  6.   <p>textarea 元素:</p>, L6 T2 [' P) j' ^
  7.   <p style="white-space: pre">{{ message2 }}</p>
    / `* O$ r; o+ K0 L: R
  8.   <textarea v-model="message2" placeholder="多行文本输入……"></textarea>( [3 ], x- a5 B& Q* a
  9. </div>
    8 E6 |3 k6 Y# ^5 `" H  _
  10. 1 k0 u  R' }, @/ c; ]
  11. <script>
    . S- u0 i9 I9 e# @
  12. new Vue({- I8 H( Y* T: Y: m
  13.   el: '#app',2 m: p% v. P, N% b# z
  14.   data: {
    1 s2 |+ G! \. d. D# L" \
  15.     message: 'Runoob',
    & x: }; ]" J' U) c: F
  16.     message2: '菜鸟教程\r\nhttp://www.runoob.com'
    ' O( h& j: h3 q+ M+ Q/ F
  17.   }$ W5 Z, d# V" e5 Q5 _2 P
  18. })6 d+ j1 k! b* R  L  J
  19. </script>
复制代码
复选框
复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组:
复选框
以下实例中演示了复选框的双向数据绑定:

  }9 V) z, H9 E& W9 N0 `5 V# [
  1. <div id="app">0 m1 v$ u' M2 L  Z7 a
  2.   <p>单个复选框:</p>
    * ~& y8 _9 Q6 }6 F: E
  3.   <input type="checkbox" id="checkbox" v-model="checked">
    0 t* U+ B' v0 U& q/ R
  4.   <label for="checkbox">{{ checked }}</label>
    . v- }, `/ `2 O& N' h
  5.     ( o* z( H4 K( a+ k! c
  6.   <p>多个复选框:</p>
    8 \( G7 ?: h6 U6 U# a$ ?+ a
  7.   <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">% p( C( M  _" V2 i
  8.   <label for="runoob">Runoob</label>
    8 {/ V: k# N' s# V, H# P* z
  9.   <input type="checkbox" id="google" value="Google" v-model="checkedNames">+ Q5 ?1 Y% @3 T) n
  10.   <label for="google">Google</label>! V) d; `5 t* j7 l
  11.   <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">7 V8 I+ m3 z% L0 b: @
  12.   <label for="taobao">taobao</label>
    , ~( S# }# y( b' J7 |
  13.   <br># p! l( p/ q; x0 q! R# R
  14.   <span>选择的值为: {{ checkedNames }}</span>
    & _" x+ ]8 z7 T% x
  15. </div>
    + J2 y6 l$ p9 J" S# x6 r# H

  16. & V3 I* ?9 r) w5 V
  17. <script>
    4 P" U/ ]3 y1 Y* N+ c
  18. new Vue({
    ) n, U/ A+ _( t& o  g
  19.   el: '#app',% r" ]1 G7 j2 {1 x
  20.   data: {
    6 Z( U4 V3 r- f" v) k
  21.     checked : false,
    : u0 ]) j5 o1 y1 z' j
  22.     checkedNames: []9 m9 c9 a2 K8 Y/ T3 X/ ^! {) T
  23.   }
    5 Y1 k# C# ]) f0 m# W( b
  24. })9 N+ y) s. }: b- i& b
  25. </script>
复制代码
实例中勾选复选框效果如下所示:
单选按钮
以下实例中演示了单选按钮的双向数据绑定:
单选按钮1 d- ~$ D, ~6 M2 X: ?3 r# @
  1. <div id="app">
    , u; e. e, J& ]' @! l1 \0 w. ?
  2.   <input type="radio" id="runoob" value="Runoob" v-model="picked">5 W1 m( f+ I* [+ N" t/ C; }
  3.   <label for="runoob">Runoob</label>3 s0 R4 g& Z/ ^3 i, m+ `& U5 t0 M" h5 C
  4.   <br>
    . V  v* X4 c; ^* \
  5.   <input type="radio" id="google" value="Google" v-model="picked">$ u: a3 Q. D9 L* i1 }$ m
  6.   <label for="google">Google</label># B; ?$ \5 V, B& g. ^. w
  7.   <br>
    2 u4 |4 T9 o+ z* K) S( z3 n
  8.   <span>选中值为: {{ picked }}</span>
    # r, W. J0 s1 q' P
  9. </div>
    + k3 B$ X; c/ u  ~' ~

  10. * S  n1 ]2 }6 @- B: v7 I
  11. <script>
    & n0 k: V9 x1 t
  12. new Vue({( ^/ r* `' S8 \& O
  13.   el: '#app',+ u/ Q4 \! n4 A+ Y' y
  14.   data: {
    3 T3 L+ D: ]; s; Z3 C
  15.     picked : 'Runoob'
    7 B8 H) P0 L+ K: [% Y6 H
  16.   }' C/ L" q0 F9 w- J$ r: ]
  17. })& J9 j, s: n/ ^1 Z- ~
  18. </script>
复制代码
选中后,效果如下图所示:
select 列表
以下实例中演示了下拉列表的双向数据绑定:
select5 x$ M& J& G7 R# i. u1 X. t# I2 N
  1. <div id="app">
    # A/ |( a+ d+ x+ V
  2.   <select v-model="selected" name="fruit">7 U% Z, p& y/ B  w
  3.     <option value="">选择一个网站</option>' A5 M2 }" `2 B' f& l) P+ l
  4.     <option value="www.runoob.com">Runoob</option>) c+ T7 ~( ^9 `- x+ ^
  5.     <option value="www.google.com">Google</option>
    / q7 a4 N* v4 a# |. S1 V2 z, X  E
  6.   </select>
    6 X, L! V' Y( |" [' |& v4 y$ X

  7. + P( x0 l8 U- d. m- W( T, x3 e  I
  8.   <div id="output">
    8 c$ Y- l9 f0 F/ b1 m
  9.       选择的网站是: {{selected}}! _, a9 A4 o* C% h: Y# @
  10.   </div>8 b& i7 j- d1 ^" s8 r0 d( X
  11. </div>0 Q9 l5 E5 R8 ~6 y; h
  12. # G  ]" ]! h; \7 q' t
  13. <script>
    $ p' b$ I. O, ]5 h" D2 t! ^
  14. new Vue({2 v# R, v% ?9 h  v9 e: {
  15.   el: '#app',
    ' ]8 F- b# J. p
  16.   data: {( l% |9 F% h; Z; h' X, ~+ m
  17.     selected: ''
    ' Q- E% w, T1 _0 v2 a! a6 o
  18.   }
    9 B+ e/ i$ L6 D" w% J
  19. }); |8 E2 U2 Y4 x1 F: ^. Q/ {, M. L' r
  20. </script>
复制代码
选取 cncml,输出效果如下所示:
修饰符.lazy
在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步:
  1. <!-- 在 "change" 而不是 "input" 事件中更新 -->1 }5 N" {* W' q0 f0 Q' ?$ ^
  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({6 Q4 R9 F, d$ ?* ~& [
  2.     el: '#app',) ]* v6 t7 x) x
  3.     data: {# J( L3 S7 K5 z. m
  4.         checked: false,6 [" M5 u$ p8 s# S; h: v; u
  5.         checkedNames: [],
    * t2 J2 T( p; f& g
  6.         checkedArr: ["Runoob", "Taobao", "Google"]* J; ~/ R# j$ q  n5 P2 I; x! `
  7.     },8 W4 b4 z( Q" T/ P# _$ L+ x
  8.     methods: {
      i0 m2 L' x4 H5 s+ ^* r
  9.         changeAllChecked: function() {
    % T& G- C: v2 ^6 \6 Y9 a+ y
  10.             if (this.checked) {; `& q8 k$ U2 x
  11.                 this.checkedNames = this.checkedArr/ P4 g" e. p* Q0 b( W
  12.             } else {# ?; f" S& P; m$ _3 o
  13.                 this.checkedNames = []
    ; t) ?1 b7 L% |0 e* h  {5 ^9 s
  14.             }  y* s7 c9 c6 ?5 Z
  15.         }. Z) @/ R0 Y; q( @3 U0 f" L0 S0 y9 C
  16.     },
    " m( l+ }- E; d1 s# {8 A8 G/ i
  17.     watch: {
    8 ^" `4 O' Y* k; \" m' v
  18.         "checkedNames": function() {) q7 O& \3 N" i: W) ]9 B6 A
  19.             if (this.checkedNames.length == this.checkedArr.length) {+ ^& u& ~' k' I; T2 [  s5 ]
  20.                 this.checked = true6 e( q! _, Y" P+ Z; L3 e
  21.             } else {$ H7 c& F3 D, d9 Z
  22.                 this.checked = false/ b+ ^* \, ]4 x3 b7 x% j! J
  23.             }3 r* b- \5 ^  G( H
  24.         }) o; r/ v! H  \
  25.     }
    7 p7 J0 |: Y* m. O4 H5 S( Z
  26. })
复制代码
- D  J5 m- N+ ~1 v% X6 I% T
3 T2 h5 Z+ E" K; J
- ?2 [: {$ N7 o% f7 U" X7 {
; y; F% C- `8 k
  Q4 h$ E3 z1 f1 Q% j2 K

- U1 [8 X8 A6 R7 Q# @
% t7 F  g9 X- G# f( N, a8 s) ]) F8 l/ q, Q9 s/ U/ E! a0 P1 S
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-6-20 01:34 , Processed in 0.071998 second(s), 22 queries .

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