' a( G. p7 K0 I1 l* G本章节,我们将为大家介绍 Vue.js 监听属性 watch,我们可以通过 watch 来响应数据的变化: 实例# P" n7 F: `3 o4 a& h
# \% p+ c6 @$ W, r; B4 o5 e- <div id = "computed_props">
. x0 Y+ @+ ~; Q0 O' X- D8 ~ - 千米 : <input type = "text" v-model = "kilometers">7 E: N5 A- k6 N4 l2 i4 G/ D: s
- 米 : <input type = "text" v-model = "meters">
8 q' }- M: [& u7 x: V; r6 E7 U - </div>
$ D7 q+ k! K$ j7 C3 T - <p id="info"></p>) T$ Q: {9 C: c: {
- <script type = "text/javascript">
, l0 s5 `8 S6 B+ {- Q - var vm = new Vue({6 \3 Y {# s) K
- el: '#computed_props',
" w5 V5 E6 r$ c8 @- L - data: {
2 p& j ]4 _8 a; L0 ] - kilometers : 0,2 ]: t2 H% X/ [1 t' `
- meters:0
4 i7 y+ H7 N1 o$ B& N) D9 r - },
" K( Q. i# m/ S) C+ P - methods: {
G" @$ d4 j* S - },; P8 H- ]: U" ~1 F' O
- computed :{0 K* v# k8 Y' V
- },
' @ g6 v" M: B% a - watch : {
4 x/ R, E) @/ c8 g5 d - kilometers:function(val) {
$ C4 _4 `2 n* C) k. q* L - this.kilometers = val;
; H# T5 I+ _! Y; J% O; E. ^ - this.meters = val * 1000;) }4 t3 k6 J8 Z( ]4 {
- },
( R$ y, w [% J l- A: j - meters : function (val) {; I S- g5 u: Q# X: I2 a
- this.kilometers = val/ 1000;
6 Q* o( w" z( ^% t6 I6 j4 m - this.meters = val;, Q# f7 D) {/ `* t- {. N& ~
- }" M+ R" q' m3 ~. a5 D
- }4 b0 i0 @& f+ U" V0 M+ y4 s
- });- t6 }; r, I x! o3 z7 R
- // $watch 是一个实例方法
# s. ~4 j; d1 m v4 V - vm.$watch('kilometers', function (newValue, oldValue) {
) ^7 g2 T, E) n& i3 { - // 这个回调将在 vm.kilometers 改变后调用
; p' n3 w2 K2 t0 O: I" E - document.getElementById ("info").innerHTML = "修改前值为: " + oldValue + ",修改后值为: " + newValue;
h" {. y5 I2 l - })
6 w8 s- ?; k. y - </script>
复制代码以上代码中我们创建了两个输入框,data 属性中, kilometers 和 meters 初始值都为 0。watch 对象创建了两个方法 kilometers 和 meters。 当我们再输入框输入数据时,watch 会实时监听数据变化并改变自身的值。 7 D9 k( ^! v& @# C
" s# A& B8 }+ Q
8 z7 \( w5 l$ p) m' J/ Z. F$ |0 J. {/ ~/ |
|