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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({. j3 m& x* m' [0 d
  2.   // 选项
    , A, ?& k4 D7 k  r9 g
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">+ q, H$ f' U( W0 u( [6 D1 \, y
  2.     <h1>site : {{site}}</h1>5 |% T# ?; a# N1 \1 Y
  3.     <h1>url : {{url}}</h1>, K/ y8 `  ]# U3 ~: t+ |
  4.     <h1>{{details()}}</h1>3 j) G% q7 J0 c2 }# S
  5. </div>- G. {! [' _3 M9 z
  6. <script type="text/javascript">- y: j) u* i3 l1 e4 O. P% r
  7.     var vm = new Vue({. N  {- ~8 L8 {8 N( ~
  8.         el: '#vue_det'," h: u: |. G  M- k
  9.         data: {
    0 L+ U; Q7 D2 ~
  10.             site: "菜鸟教程",6 v2 {/ o% [; d3 A
  11.             url: "www.runoob.com",
    $ `( W/ H' ^3 f+ n$ i
  12.             alexa: "10000"' P5 c2 l4 W# b: ~. K( i6 O1 t) ~
  13.         },
      M* I9 P9 e; S" r7 f
  14.         methods: {( P0 m0 C% R- Z: y7 p2 Q
  15.             details: function() {6 ~# @1 z# s) g% {* {4 `
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";9 K7 @; ~/ X0 Y& h' t$ u, M
  17.             }" a3 v% P3 R& k  c; a$ \
  18.         }
    5 a4 G. K" H5 E& K1 j3 {/ o' p1 t
  19.     })
    / w0 ]+ n/ Y7 N. s; @7 q& H
  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">+ e9 m! y& ]) Q+ [/ J; O/ |% S
  2.     <h1>site : {{site}}</h1>7 H5 `# v* g- [/ W
  3.     <h1>url : {{url}}</h1>
    , Q7 z& X  e) ]* L
  4.     <h1>{{details()}}</h1>/ G5 t- Q1 N% |5 y
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">/ g) `! ~4 }: a! b/ d
  2.     <h1>site : {{site}}</h1>
    4 Z2 i; [0 _* U; w; `1 q
  3.     <h1>url : {{url}}</h1>
    9 H& Z6 D7 ?4 N
  4.     <h1>Alexa : {{alexa}}</h1>
    5 c- _4 e7 A3 C' w
  5. </div>
    : t% v& {: p5 M+ q9 P" K
  6. <script type="text/javascript">
    4 I5 X/ X+ P0 J3 m; J0 m; J* `
  7. // 我们的数据对象4 `. a" b9 _, R% C, [. y- F) r
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    ( E0 e+ I! Y& `; }) B# L
  9. var vm = new Vue({
    ) d3 F4 o* X. k2 p- T
  10.     el: '#vue_det',
    8 u, c9 S8 \8 p, i. j9 g
  11.     data: data- j( w. F2 H( ]5 D# m1 y$ B- F
  12. })1 `# p" J7 J7 @- Z1 y6 |, `
  13. // 它们引用相同的对象!  i9 [3 r0 U7 S) `+ [
  14. document.write(vm.a === data.a) // true
    & c9 h" q7 s' ~; @$ X* M
  15. document.write("<br>")! B( y( a& x. ]" P3 u/ ?" ^
  16. // 设置属性也会影响到原始数据
    / G% ~5 y9 W: Z& k
  17. vm.site = "Runoob"
    3 {% E9 a, u# C) C) _, M
  18. document.write(data.site + "<br>") // Runoob
    2 _7 P' h& a% B* {

  19. 4 h6 n, M" f! ~
  20. // ……反之亦然7 V/ G) y! T+ c1 Q" \
  21. data.alexa = 1234. C, y% j- k2 p7 k# l) x
  22. document.write(vm.alexa) // 1234
    " d5 l: e& ]) C5 P8 X' D
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    * |- E" G5 ?) u+ c7 o, o1 i
  2.     <h1>site : {{site}}</h1>
    0 p5 d& C- U9 X$ l& Z* n
  3.     <h1>url : {{url}}</h1>* O6 T) D) K2 n: V8 o* c2 s3 }
  4.     <h1>Alexa : {{alexa}}</h1>+ h1 n( ]* d. z9 \$ H: y. [
  5. </div>) W$ t2 `- ?3 C' M0 |+ D
  6. <script type="text/javascript">
    ! G0 e/ n0 ~6 ?9 i
  7. // 我们的数据对象
    * t$ S. k1 s1 @- O& b, x0 J
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}' y( V( K" r2 w* ]6 j6 S. K
  9. var vm = new Vue({, \9 ^- N( _* N: y2 F- P
  10.     el: '#vue_det'," z$ L. d- J; ~+ Z7 Q; @  ]
  11.     data: data
    # n. y  `, C4 E
  12. })
    9 y4 I, U8 T4 s9 K" Y# O& k

  13. - S/ x. W  u. C; w4 x
  14. document.write(vm.$data === data) // true: d; O! {0 }& Q. b  M. ?
  15. document.write("<br>") // true2 G- ?9 U, A$ t4 R" J4 s' G
  16. document.write(vm.$el === document.getElementById('vue_det')) // true6 \; m; \7 |, o. F7 a
  17. </script>
复制代码

: s4 ]/ |# \% ~7 F1 J3 [  J- F8 N- h* S# S. J5 d
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-1-30 15:02 , Processed in 0.049708 second(s), 20 queries .

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