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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 表单

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-4 11:22:23 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
这节我们为大家介绍 Vue.js 表单上的应用。
你可以用 v-model 指令在表单控件元素上创建双向数据绑定。
v-model 会根据控件类型自动选取正确的方法来更新元素。
输入框
实例中演示了 input 和 textarea 元素中使用 v-model 实现双向数据绑定:
* M' _! U: [; u" R  B9 J2 w
  1. <div id="app">- t+ ^( \- |3 A3 W
  2.   <p>input 元素:</p>
    " D* A  K" ?; H' L# J) X
  3.   <input v-model="message" placeholder="编辑我……">8 S' c$ E4 a2 l7 F0 q
  4.   <p>消息是: {{ message }}</p>8 n% K* C. l; p* {& m" x/ \/ |
  5.    
    8 w+ g" Z8 [/ A8 H7 {& i  v& j8 I
  6.   <p>textarea 元素:</p>
    8 L& a% G3 V- D; u! m4 R, F8 w4 k
  7.   <p style="white-space: pre">{{ message2 }}</p>
    6 k9 `: V3 W  F- n3 m' o. N
  8.   <textarea v-model="message2" placeholder="多行文本输入……"></textarea>
    ; U# I4 s9 o/ Y( x/ w, R
  9. </div>6 G( [+ h$ S7 i3 f! E9 h

  10. . p4 P7 d* Y+ Q
  11. <script>% z' M  r/ W+ O2 ?2 F& A2 N
  12. new Vue({; n4 `, N! x. h  b# P- U' F
  13.   el: '#app',
    + O: n* `4 M5 S
  14.   data: {  ]( P! U3 V" f' ]3 b. ?
  15.     message: 'Runoob',
    % ]) o1 M4 j, n/ j( ]
  16.     message2: '菜鸟教程\r\nhttp://www.runoob.com'" R5 v# o9 h  M  K- B) j" c( m. X
  17.   }& p# L5 S8 N0 d' L- Z7 Q1 O
  18. })+ q, U$ P& i# r6 O, Y
  19. </script>
复制代码
复选框
复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组:
复选框
以下实例中演示了复选框的双向数据绑定:

4 r" X/ ]4 u3 \- f0 U( S6 V
  1. <div id="app">
    * i  ^7 n# y5 L  c& Z
  2.   <p>单个复选框:</p>0 W0 D4 |& t8 F# a9 E( n5 @6 D
  3.   <input type="checkbox" id="checkbox" v-model="checked">. M$ `+ K  Q0 m% l0 J* `
  4.   <label for="checkbox">{{ checked }}</label>
    , l* H1 D% \9 p' p
  5.     " |8 Z2 S: [- @/ _0 \- ^% M/ a
  6.   <p>多个复选框:</p>. D3 m, [1 y. n9 _7 F+ J5 {! A  o( D/ B
  7.   <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">$ Y' `+ k1 v# Z( F
  8.   <label for="runoob">Runoob</label>" r. R+ I: S( {" e# U
  9.   <input type="checkbox" id="google" value="Google" v-model="checkedNames"># I  c/ l6 R: A8 S( o
  10.   <label for="google">Google</label>' d% R# Y0 B; {4 [
  11.   <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">! I, E  a  r. z9 K; T# ^5 k' [5 ^
  12.   <label for="taobao">taobao</label>) V+ P6 O! K2 Q" A) ]( E0 \
  13.   <br>
    4 U$ }; D% ]3 Y' U+ \. y
  14.   <span>选择的值为: {{ checkedNames }}</span>
    0 e1 p, V9 X2 l; X- G0 m
  15. </div>8 ~* l! c' z7 y
  16. / U! Q5 {# ]2 v! r: q8 L; y
  17. <script>
    & I& h$ `3 b. k  p
  18. new Vue({! G+ @2 C' a1 S; D  R. k4 I. j8 A( d
  19.   el: '#app',; ^/ f# p" z# ?& ?
  20.   data: {) c( W5 ]# [5 q6 v9 c
  21.     checked : false,
    , E* i9 k6 r& A
  22.     checkedNames: []& b$ _& I( i6 J6 {% p! W% `2 S
  23.   }+ X: V1 o/ {9 N4 O( g
  24. })5 e( h- U' l! e' ~& R8 v' Z
  25. </script>
复制代码
实例中勾选复选框效果如下所示:
单选按钮
以下实例中演示了单选按钮的双向数据绑定:
单选按钮8 h! q7 B# V3 J) w- U- C
  1. <div id="app">1 c" f2 w# W- L7 m7 a7 A8 D: u
  2.   <input type="radio" id="runoob" value="Runoob" v-model="picked">
    2 r! g, J, B  X
  3.   <label for="runoob">Runoob</label>
    2 d8 m; ~  d+ L- R' D
  4.   <br>" G2 X2 E4 ?% a/ E" l) j% [
  5.   <input type="radio" id="google" value="Google" v-model="picked">
      p' u8 }7 ]7 }6 p
  6.   <label for="google">Google</label>
    $ I( R) |& t& Y# M- M
  7.   <br>
    ! {7 t; X/ _2 F( K. {
  8.   <span>选中值为: {{ picked }}</span>* U: r; d# V. T, e" A
  9. </div>2 b3 F( }1 ^$ G) r# E
  10. , }+ j. e  A# \3 N2 r2 ^
  11. <script>1 ^- A$ t5 N' K/ A8 l: l( `6 P1 l
  12. new Vue({
    ) b2 q0 M0 o% E/ @- T) `
  13.   el: '#app',
    6 N/ @' z& f. k3 Y9 _- G
  14.   data: {. Q5 `: x( S3 p0 a$ h9 [* e, l! K
  15.     picked : 'Runoob'
    8 q" \3 A9 U; ?5 K
  16.   }- S+ e1 l1 j8 Y1 ]- a
  17. })" d) Z: W9 A! d  g" {
  18. </script>
复制代码
选中后,效果如下图所示:
select 列表
以下实例中演示了下拉列表的双向数据绑定:
select" ^- F2 y& s& T$ _
  1. <div id="app">
    ! D( ^! f6 I" e0 R
  2.   <select v-model="selected" name="fruit">+ E  v# j$ E* `/ E% I! |
  3.     <option value="">选择一个网站</option>
    # A) Z8 _, R5 s
  4.     <option value="www.runoob.com">Runoob</option>( J; K4 u5 j& i8 g4 \' [
  5.     <option value="www.google.com">Google</option>
    ; G1 L0 ^0 k$ @! q+ {: J" [
  6.   </select>+ F, C& c' Z; @1 p* j9 ?

  7. & z! K% T7 R$ ~# ], o
  8.   <div id="output">
    - U) F9 R2 K2 E
  9.       选择的网站是: {{selected}}( y8 \/ n/ e2 L/ Y$ V5 a' y
  10.   </div>
    + U$ i1 L6 x" Y# I5 `7 e
  11. </div>, `) C/ F: n0 Z( |: D8 j
  12. 8 `0 \4 X4 f4 ^1 H  }9 t. r# f, p
  13. <script>
    + p2 k. y+ R; R
  14. new Vue({
    1 J! N) L5 I# |  J0 J1 ]  z
  15.   el: '#app',
    ( c; X0 B- m/ G
  16.   data: {
    9 ?/ h7 ^1 j5 f# z0 a
  17.     selected: '' , m4 b3 M. I( P6 G! L' K
  18.   }% }4 _8 ^0 [- A# }* W9 N
  19. })
    ) c! M/ c! j& L; d5 c1 H
  20. </script>
复制代码
选取 cncml,输出效果如下所示:
修饰符.lazy
在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步:
  1. <!-- 在 "change" 而不是 "input" 事件中更新 -->
    : H6 X) ?9 {4 C6 ]& e; 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({
    1 n1 N7 R+ D2 d) h8 {
  2.     el: '#app',
    4 s- Z8 P) x1 I; Z3 l) A  _
  3.     data: {; o3 `5 w3 N+ m* z" W
  4.         checked: false,, r+ X1 Y( w3 v4 m0 z
  5.         checkedNames: [],; z- I- [8 t2 B% ?' K+ @$ K
  6.         checkedArr: ["Runoob", "Taobao", "Google"]
    4 @: i7 p$ Y) o
  7.     },
    ! r1 F* Q9 L- S& c. ^" ~
  8.     methods: {4 G6 c" N& A" j) C6 X) p- L& Q
  9.         changeAllChecked: function() {. P. V3 u6 C3 e( [& X1 W: O4 X7 e
  10.             if (this.checked) {  q. y- u# D0 Q& P9 y& C& i
  11.                 this.checkedNames = this.checkedArr
    - G, m3 R' I( ?% ]9 D: L5 m3 m
  12.             } else {
    : Y8 v8 C; V% O6 ^1 B" f+ B
  13.                 this.checkedNames = []
    # H) c5 Y" T$ Q6 ]8 R/ ]
  14.             }
    # B$ v, F8 W+ a8 e$ m' T
  15.         }
    0 ~: G7 }! L* h( {$ k8 A, a  m2 _' v6 ~1 u
  16.     },
    4 F' G' \. l7 F" N
  17.     watch: {
    , l/ L  d8 I* n- k
  18.         "checkedNames": function() {
    % U. K. S0 R& p& D
  19.             if (this.checkedNames.length == this.checkedArr.length) {- H9 X4 p! `0 [2 g* k" B
  20.                 this.checked = true
    ) r/ a5 o9 s9 ?+ u
  21.             } else {2 W, _7 A8 G9 i5 A; |- o, C+ q
  22.                 this.checked = false
    1 X. D6 f  q! q- m2 {& }
  23.             }: A" @/ C: G4 y( g$ W& q7 ?/ x! n* v
  24.         }, _( m2 }: R: R2 L
  25.     }
    4 Y$ {' j6 T" |$ Q
  26. })
复制代码
* v) Y: T/ D' _; D! z
, K* k7 n3 u  e  W# e
1 A8 y* G4 }$ m
4 E! U/ p4 H  Z/ ]" @3 H$ p, e
! _$ O* N. C- _/ Q

8 W6 c0 [4 E- g- ^6 A, {8 `8 j6 H) t) z

& g( O8 z  V' a7 T# e
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-6-26 09:51 , Processed in 0.130354 second(s), 23 queries .

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