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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[Vue.js] Vue.js 起步

[复制链接]
跳转到指定楼层
楼主
发表于 2018-7-1 23:08:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
Vue.js 起步
每个 Vue 应用都需要通过实例化 Vue 来实现。
语法格式如下:
  1. var vm = new Vue({
    ! g* H% q, V: Z1 D! \* S
  2.   // 选项
    " a! ?% T0 L  S: g, O" B/ J
  3. })
复制代码
接下来让我们通过实例来看下 Vue 构造器中需要哪些内容:
  1. <div id="vue_det">5 a6 v* P7 b# X  C1 ], {
  2.     <h1>site : {{site}}</h1>' R3 ]# C+ t. d' E' M: N. e
  3.     <h1>url : {{url}}</h1>( r8 z! Y% e2 I; F0 s. S
  4.     <h1>{{details()}}</h1># h) ^2 t  F* O  H; A# T$ R
  5. </div>& V# b- E2 G1 \) R" h# N7 z( N
  6. <script type="text/javascript">
    . Q/ y  G5 F* e
  7.     var vm = new Vue({
    8 `' r. B6 q5 g2 b& h
  8.         el: '#vue_det',
    ) a4 X1 b4 m$ }1 ~* [
  9.         data: {
    ( @! g1 ?4 {  }1 o+ {
  10.             site: "菜鸟教程",- E2 P7 |4 y9 Z5 e  b
  11.             url: "www.runoob.com",3 ]( Q, |( R' q! q/ D! O
  12.             alexa: "10000"' e! M6 Y" I( Y6 r! A. O) Z9 }( S9 M
  13.         },
    9 Y4 ^" b6 o! n% L0 V( M% d
  14.         methods: {
    4 E8 ^* X. x6 ?
  15.             details: function() {5 o$ f) f5 y2 x6 w
  16.                 return  this.site + " - 学的不仅是技术,更是梦想!";
    ) q8 m4 A! x- N+ z8 [
  17.             }
    5 A5 j: J: b9 H2 r8 ]' N
  18.         }' H: J- F/ P9 H  h5 R: h
  19.     }); Y7 \1 I- L6 |  Q# M
  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">$ d- X8 ~& U( Q+ e( d/ c
  2.     <h1>site : {{site}}</h1>
    : J# s( {3 V# @; [2 \
  3.     <h1>url : {{url}}</h1>
    7 t) S4 f; Z- V* o# \! {) _
  4.     <h1>{{details()}}</h1>. X" ]3 r" }1 S
  5. </div>
复制代码
当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其 data 对象中能找到的所有的属性。当这些属性的值发生改变时,html 视图将也会产生相应的变化。
  1. <div id="vue_det">
    1 O. z# {, |+ _$ R/ _3 T
  2.     <h1>site : {{site}}</h1>; ?2 v% `# x5 N4 _
  3.     <h1>url : {{url}}</h1>
    " D" f8 Q8 y/ c: Z' e3 U. l
  4.     <h1>Alexa : {{alexa}}</h1>
    , ?1 `5 S6 F- y4 o0 Q+ ~
  5. </div>
    $ S0 X' f- T! s: q0 g/ |$ l  V1 f
  6. <script type="text/javascript">
    6 g6 g; ^+ N8 h0 D4 Z9 b
  7. // 我们的数据对象- W1 Q4 U" z9 X6 R( ]3 |# U2 M% j
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}* e2 L' S9 m, s9 T1 P1 ]% D7 k$ c# `: s
  9. var vm = new Vue({
    # i: A$ Q  p  O4 E! t
  10.     el: '#vue_det',
    7 y6 o. |! C% p
  11.     data: data  q1 d" O0 W% Z) u( D+ X( P: ?
  12. })! u; r5 o) F- ~7 R2 V4 F6 a2 C$ o+ S$ n
  13. // 它们引用相同的对象!
    1 e  a, a6 V/ o; y" H7 X
  14. document.write(vm.a === data.a) // true
    % I7 I, j- S  v& n, j4 s- r9 v3 |) a# _
  15. document.write("<br>")4 i% f4 e9 l3 J& |+ C' E- {
  16. // 设置属性也会影响到原始数据
    / m8 \0 |4 E( Z# \" W
  17. vm.site = "Runoob"1 L" P% G3 G. b3 d7 c# v4 J1 q$ ]
  18. document.write(data.site + "<br>") // Runoob2 S, u' K+ J/ \! ^
  19. + E. P- A4 Q" S( e$ Z* ^- Q4 B
  20. // ……反之亦然+ o( m; b/ d' ^2 T
  21. data.alexa = 12344 y) }+ m! Q9 U( P/ A0 K
  22. document.write(vm.alexa) // 1234* M  |% x7 X& I/ h- H- g
  23. </script>
复制代码
除了数据属性,Vue 实例还提供了一些有用的实例属性与方法。它们都有前缀 $,以便与用户定义的属性区分开来。例如:
  1. <div id="vue_det">
    ' }( o6 T4 r8 l. z/ F
  2.     <h1>site : {{site}}</h1>
    7 Z0 n0 m& N4 ]7 g4 @3 [( r  l
  3.     <h1>url : {{url}}</h1>% T: c' W7 j* m* g
  4.     <h1>Alexa : {{alexa}}</h1>
    8 j2 B& _3 F, d6 p" u; F7 u) ?' ]$ f
  5. </div>
    ; i$ s9 W; W1 n* a
  6. <script type="text/javascript">
    # I" p/ p' J8 u4 F/ f1 Q
  7. // 我们的数据对象9 N9 G. n  {  S$ U! b+ V
  8. var data = { site: "菜鸟教程", url: "www.runoob.com", alexa: 10000}
    - [1 K' R5 _4 N! ?6 _0 w$ T
  9. var vm = new Vue({* w# c0 q: f: V
  10.     el: '#vue_det',
    ; e% ?' j' t9 h* r
  11.     data: data
    4 Z0 \9 Y: \; \* _: g
  12. })1 H' k. j% W  j$ l! ?/ `( U

  13. ' C$ ~: w+ G/ F% C
  14. document.write(vm.$data === data) // true! b$ m# [0 k; a3 [) B/ O4 D
  15. document.write("<br>") // true
    - X8 y0 u+ e! V& ?* |% u0 H
  16. document.write(vm.$el === document.getElementById('vue_det')) // true, `) t$ @% l8 s" E  [
  17. </script>
复制代码
8 K  c/ O/ s9 M" a9 S

% k# j; \% w  L0 P
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 21:06 , Processed in 0.126627 second(s), 20 queries .

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