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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    2 K% Y0 j* L/ l+ p9 o) m9 |7 \
  2.   // 选项
    & p' L. {# A5 t3 @
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">% e6 K! _. A- B  y; n
  2.     <h1>site : {{site}}</h1>
    9 l, S' k! u4 K+ v  ~4 ~
  3.     <h1>url : {{url}}</h1>) `; s) f$ g( U2 J
  4.     <h1>{{details()}}</h1>: W8 ]; l+ [( ^9 c: W8 y( i
  5. </div>
    ! w* n5 g# _! K3 L/ c% t0 j
  6. <script type="text/javascript">
    1 Z" m& Z4 v7 p; A5 X
  7.     var vm = new Vue({
    $ D2 h. k5 F* ?
  8.         el: '#vue_det',, n1 r) L* d) ?2 D6 `6 V; S, S
  9.         data: {
    & J* H$ p& w" C3 Q
  10.             site: "菜鸟教程",
    9 }+ ~3 [$ \* s; J
  11.             url: "www.runoob.com",
    . ^- U; A. r& q% o0 f( T1 j2 g
  12.             alexa: "10000"
    3 h" b# l2 _- X# }1 ?, j
  13.         },$ k  w+ ~+ a( Q* h/ @
  14.         methods: {
    " p/ a$ L, f9 e9 d
  15.             details: function() {
    + {* z2 v2 ~9 f% v. D
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    + v/ E0 _' W" j) f0 s4 {5 J
  17.             }
    ; @3 T& c3 G8 y# f
  18.         }; G3 ]/ R% Y. F: N. |3 F
  19.     })* o' M, p" T2 F) Q4 g, H" w
  20. </script>
复制代码
可以看到在 Vue 构造器中有一个el 参数,它是 DOM 元素中的 id。在上面实例中 id 为 vue_det,在 div 元素中:
  1. <div id = "vue_det"></div>
复制代码
这意味着我们接下来的改动全部在以上指定的 div 内,div 外部不受影响。
接下来我们看看如何定义数据对象。
data 用于定义属性,实例中有三个属性分别为:site、url、alexa。
methods 用于定义的函数,可以通过 return 来返回函数值。
{{ }} 用于输出对象属性和函数返回值。
  1. <div id="vue_det"># ]7 _& ^, Q* s
  2.     <h1>site : {{site}}</h1>
    7 d+ ^: `1 g7 W9 {; b; n# L
  3.     <h1>url : {{url}}</h1>
    % G- `0 C$ _. U3 j& ~. d
  4.     <h1>{{details()}}</h1>
    # k; F0 y$ Z# Y; X# ~8 t& h: P0 q- [
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">7 y" v$ k* t2 l- `% E& G; P' e1 F. e
  2.     <h1>site : {{site}}</h1>
      b; x9 H. r$ U5 S  d) Z+ Y. I  b3 V
  3.     <h1>url : {{url}}</h1>6 d( }, {8 d) r2 L3 ^
  4.     <h1>Alexa : {{alexa}}</h1>8 T, r1 B1 h+ N
  5. </div>
    , x0 U1 s9 ~2 N; a( {
  6. <script type="text/javascript">
    ( c6 L5 I, [7 o; p, U# C
  7. // 我们的数据对象6 w) Z, ~) A' b9 s/ w
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    0 y5 i+ b* M1 U1 d
  9. var vm = new Vue({
    % o' @8 ^/ c0 X6 r4 a6 @
  10.     el: '#vue_det',
    ( L) Q1 p: R# Y9 k0 w
  11.     data: data) t' l! S; a# U8 |+ {1 Y
  12. })
    5 ?8 d: q9 L4 E
  13. // 它们引用相同的对象!
    # t! l& O, Q! }* ?' k1 M
  14. document.write(vm.a === data.a) // true/ u& {3 p5 r" v7 j2 j& M# S3 ~
  15. document.write("<br>")
    8 q! A: ?1 V* x4 H- m
  16. // 设置属性也会影响到原始数据
    & U8 y( G3 }; K' t* f
  17. vm.site = "Runoob"( D5 K- t: b2 C& C
  18. document.write(data.site + "<br>") // Runoob
    ; ~+ B/ T3 y/ b2 Z: y% @
  19. * `$ H4 ?0 E* \7 _: ?
  20. // ……反之亦然
    # u7 c3 [8 J( x6 I, C: r
  21. data.alexa = 12342 p8 [# P- A' N, H7 j6 ^$ p0 S. ?
  22. document.write(vm.alexa) // 1234( f  j* q! R* _8 W# ]
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    5 h' q, z' S) A0 U
  2.     <h1>site : {{site}}</h1>$ p4 p' _" v* w. n# b& f
  3.     <h1>url : {{url}}</h1>8 [. _+ E+ g! Y
  4.     <h1>Alexa : {{alexa}}</h1>( X+ W$ w) v; m. P/ P' F
  5. </div>
    % l/ K2 W- D( G* }2 r( ?) a
  6. <script type="text/javascript">
    1 ^# I0 Y( h4 X, `+ a
  7. // 我们的数据对象
    3 M0 o7 `- G  X: d8 A- }; X: t
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    . G* a  X: e; Y; h) u' l" C4 \
  9. var vm = new Vue({
      L5 M7 n! c7 O' c9 v/ t, [
  10.     el: '#vue_det',& H5 q) Y: O; R
  11.     data: data& A0 A; ^( f1 x! Q
  12. })
    & L; z5 C& V5 {; L: a
  13. 6 z( D( V+ ~- ^
  14. document.write(vm.$data === data) // true
    5 U; l9 x9 |$ z
  15. document.write("<br>") // true
    ( Y/ i/ w; C& {
  16. document.write(vm.$el === document.getElementById('vue_det')) // true7 J+ D) S; y/ X; S( J7 W
  17. </script>
复制代码

1 j' p4 T/ {5 j4 f3 }, ?4 c& A$ y8 s0 t6 s: C- K- F" K
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 16:45 , Processed in 0.064613 second(s), 20 queries .

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