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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 表单

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

& D+ r/ l' \4 h7 A, X: o, y
  1. <div id="app">" M. B9 p) S* C3 w" J4 q8 t! c
  2.   <p>input 元素:</p>- M* l( a) p* s
  3.   <input v-model="message" placeholder="编辑我……">
    / ?: m! A, s; l  W/ U+ P
  4.   <p>消息是: {{ message }}</p>6 k+ w+ i3 ]4 R2 z' J
  5.    
    5 ~* H% f/ F8 n5 u4 x' U# l
  6.   <p>textarea 元素:</p>8 @  n/ C( `2 ]4 f% M& A
  7.   <p style="white-space: pre">{{ message2 }}</p>& {1 O! p1 i# q6 Z$ Q! k
  8.   <textarea v-model="message2" placeholder="多行文本输入……"></textarea>, l# g( i( G7 _  [
  9. </div>/ L1 I5 C& }7 t( B! e) C' a6 b
  10. ; U5 I& f8 G1 s
  11. <script>
    ! D8 J* J+ \4 ?$ t- j& F
  12. new Vue({, d5 l3 \6 `. c5 W
  13.   el: '#app',+ Q$ M7 j: e2 R6 k# \2 ~
  14.   data: {/ A* @* V: H% m2 e6 ^4 z
  15.     message: 'Runoob',
    3 r, G3 p( U* ~1 V( M8 H
  16.     message2: '菜鸟教程\r\nhttp://www.runoob.com'! K% I, i- y3 T3 b( D3 {- V
  17.   }) Y0 }6 _. w7 c% H& b
  18. })
    7 l& Q# }0 z. z( O% g5 ]3 I5 }' {9 x
  19. </script>
复制代码
复选框
复选框如果是一个为逻辑值,如果是多个则绑定到同一个数组:
复选框
以下实例中演示了复选框的双向数据绑定:
7 N0 F* X, r7 u
  1. <div id="app">
    5 Y4 F9 i, n9 d/ z, l* r* r
  2.   <p>单个复选框:</p>
    ; v0 s" ]& \! K0 \2 v+ Y
  3.   <input type="checkbox" id="checkbox" v-model="checked">
    : L( j- L( `* N
  4.   <label for="checkbox">{{ checked }}</label>* [* p6 C/ u* E" [) {- a
  5.     " i) F$ U2 E! x) b# i7 M
  6.   <p>多个复选框:</p>/ m& I: f7 }: ?# I/ L
  7.   <input type="checkbox" id="runoob" value="Runoob" v-model="checkedNames">
    1 b7 b; V5 o3 N' ?3 {5 ?. o; R: S( |
  8.   <label for="runoob">Runoob</label>
    7 I, d4 s8 I; F5 O
  9.   <input type="checkbox" id="google" value="Google" v-model="checkedNames">3 M6 x# n6 w8 a; R9 E
  10.   <label for="google">Google</label>. k0 H6 R$ W: G4 p- O
  11.   <input type="checkbox" id="taobao" value="Taobao" v-model="checkedNames">
    : z( J5 ~2 d5 \" X+ M$ `
  12.   <label for="taobao">taobao</label>4 s0 [9 E* o4 z1 j. J
  13.   <br>
    7 h5 e2 d3 m2 c- E: l* d
  14.   <span>选择的值为: {{ checkedNames }}</span>
      ^4 ?, u' @6 q4 ~8 Y4 u# u! R- ?
  15. </div>( l5 q' s+ g2 H+ r( e

  16. # C  O  W( Y' X
  17. <script>
    , j: H* O: D: P, C' a3 J3 ]% Z
  18. new Vue({
    # v: Y8 O8 D! w
  19.   el: '#app',
    & P5 x: [0 v# F( W. Q8 u
  20.   data: {% i$ T0 `7 s3 h
  21.     checked : false,
    ( h1 `+ D! l5 R. W
  22.     checkedNames: []" e2 d6 k3 `; v
  23.   }
    : `( N+ R$ _* p! e. B. [
  24. })5 R+ ]3 a$ M  N' ~- N  H
  25. </script>
复制代码
实例中勾选复选框效果如下所示:
单选按钮
以下实例中演示了单选按钮的双向数据绑定:
单选按钮
! W& ^2 \" Z5 ?" b( t
  1. <div id="app">$ u9 a, Q5 D; A! u% L
  2.   <input type="radio" id="runoob" value="Runoob" v-model="picked">
    $ @" L/ ~2 u5 J! Y5 E9 q
  3.   <label for="runoob">Runoob</label>
    / Z& R' [0 j$ X+ o: @
  4.   <br>
    " L3 h  O& t: @& G/ Q7 \1 G
  5.   <input type="radio" id="google" value="Google" v-model="picked">3 ?* g6 ^6 _/ c6 n
  6.   <label for="google">Google</label>. ^+ y4 {1 `% _+ P- @6 O
  7.   <br>
    9 R/ x7 O1 Q$ c' C
  8.   <span>选中值为: {{ picked }}</span>
    8 Z0 j+ i6 C8 |8 v: ^$ Y
  9. </div>- }6 v8 b' o! e( A8 Z

  10. 8 W7 r* m* W4 l. }# M
  11. <script>1 h! x6 r4 @5 J! G) q& R
  12. new Vue({6 u. k; n' }( E5 M
  13.   el: '#app',
    4 E7 M  X( o% q- M& Q/ j8 L* R3 N% _
  14.   data: {
    5 n# u2 Z8 ?6 x( u% P4 g. e( B
  15.     picked : 'Runoob'6 ^' j& {  s% {8 P; N  C8 Q
  16.   }
    # }. o) k+ a4 ?# A5 Z- k; O% |& }/ c
  17. })% l, n6 ^1 Z6 U, E0 e- ^
  18. </script>
复制代码
选中后,效果如下图所示:
select 列表
以下实例中演示了下拉列表的双向数据绑定:
select; A; T& d+ G/ |& I: n( f! g. E
  1. <div id="app">1 @- M9 J0 X" G% }3 Z4 N
  2.   <select v-model="selected" name="fruit">
    - v5 g! u/ k$ |% k/ x
  3.     <option value="">选择一个网站</option>  X% ^  I0 j( `8 J0 J! f
  4.     <option value="www.runoob.com">Runoob</option>" m, t" v3 W6 |. O( {9 q% v
  5.     <option value="www.google.com">Google</option>1 `; x' _  ~- m8 v0 C
  6.   </select>; p; S; b- j3 ^7 g. t3 T  R' R
  7. % ?3 O: g2 w. _( Z6 a2 s
  8.   <div id="output">3 v3 C7 S6 E) O
  9.       选择的网站是: {{selected}}" \: |7 f/ m8 F+ L" \
  10.   </div>
    9 q% G2 l2 V8 D: e- G
  11. </div>- ]( X$ ^. O% J* ]' D

  12. + R" i' y9 ~" c/ c1 E: J8 }4 U
  13. <script>
    2 e6 y4 G) d' s8 f3 Y
  14. new Vue({; E( b/ i9 N) X/ e5 z6 n  Z$ s. q
  15.   el: '#app',
    # I' j7 `6 i; }8 t
  16.   data: {% h5 |# R$ Z+ I6 {2 n6 q+ `
  17.     selected: '' ; E) m+ N+ \% Q1 u) D1 h
  18.   }
    4 \+ s% m" i8 A- C/ {
  19. })
    2 t. H. z7 V. N$ A: \
  20. </script>
复制代码
选取 cncml,输出效果如下所示:
修饰符.lazy
在默认情况下, v-model 在 input 事件中同步输入框的值与数据,但你可以添加一个修饰符 lazy ,从而转变为在 change 事件中同步:
  1. <!-- 在 "change" 而不是 "input" 事件中更新 -->3 `. t# _" t+ y* }7 Y$ {: w
  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({
    % W; J% S* `' ^
  2.     el: '#app',' I4 E1 y' e9 ~, [: X
  3.     data: {
    - D6 x$ e) u5 M+ X5 {% V, ~! G
  4.         checked: false,  F8 U# v! y# e+ S& ]
  5.         checkedNames: [],% a! {- _; x- h& Y6 x7 D0 m
  6.         checkedArr: ["Runoob", "Taobao", "Google"]1 e6 ^  ~4 q% {) a* a% K% T
  7.     },
    - N8 E6 z% r9 o$ c, _
  8.     methods: {
    9 \. T" E6 A1 d6 }! ?3 O+ ^2 `/ h; i/ p( z% W
  9.         changeAllChecked: function() {% `5 G. w3 x+ h+ f& i" ^
  10.             if (this.checked) {% d9 k5 X' Y- N' |3 K( t8 I
  11.                 this.checkedNames = this.checkedArr# H- m8 K$ S8 K7 c6 _2 |, {0 v
  12.             } else {7 ^, c- Z3 j+ U' c" Z2 _& C, P% m  C
  13.                 this.checkedNames = []
    ; }' e0 y3 R$ L' g" z( e
  14.             }" |% K% Y) {! i+ j) H
  15.         }# h0 G+ m! y$ B7 u3 m  Q. ?# d$ [
  16.     },* r, p% B$ {% `4 C2 B9 g
  17.     watch: {; O+ o! C* F: D  |8 y/ @
  18.         "checkedNames": function() {
    " Y0 ^4 ?2 i" ?% B5 v* k5 y
  19.             if (this.checkedNames.length == this.checkedArr.length) {
    1 L, q  N8 m. B) d1 E
  20.                 this.checked = true8 c/ \+ }/ @6 S, o6 H) Y& b) ^
  21.             } else {
    ; _. S: M  _) Z2 ?4 P
  22.                 this.checked = false( K& P# u1 s3 l/ @# h- e* Z
  23.             }8 r3 i. ?8 f* [8 t- R
  24.         }
    + @2 C$ p  T0 e. ^% b! d
  25.     }
    4 ^7 S: i3 I9 Z/ `. d: a* i8 F
  26. })
复制代码

" a/ h$ \  l5 ~6 i5 A; h$ G+ t$ j' M7 L( Q8 S
  h  f# U6 B5 l! _
2 S8 c9 V( C& Y( d/ D! a

2 _! I) p$ n% c% C" m. o/ n
, [& q, [0 S7 Q
& j. _3 G6 S1 C' M* ?9 X2 l& o# Z5 F+ B* [& v8 p0 f( o% ?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-5-9 12:19 , Processed in 0.124069 second(s), 22 queries .

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