前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue之初识Vue

Vue之初识Vue

作者头像
用户1195962
发布2018-09-13 16:32:49
8760
发布2018-09-13 16:32:49
举报
文章被收录于专栏:LanceToBigData

前言

如果你之前已经习惯了用jQuery操作DOM,学习Vue.js时请先抛开手动操作DOM的思维, 因为Vue.js是数据驱动的,你无需手动操作DOM。它通过一些特殊的HTML语法,将DOM和 数据绑定起来。一旦你创建了绑定,DOM将和数据保持同步,每当变更了数据,DOM也会相 应地更新。

一、Vue简介

1.1 渐进式框架-Vue

vue官网说:Vue.js是一套构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计。 渐进式我个人理解就是阶梯式向前。vue是轻量级的,它有很多独立的功能或库,我们会根据 我们的项目来选用vue的一些功能。就像我们开发项目时如果只用到vue的声明式渲染,我就 只用vue的声明渲染,而我们要用他的组件系统,我们可以引用它的组件系统。 vue的渐进式表现为:

代码语言:javascript
复制
声明式渲染——组件系统——客户端路由——-大数据状态管理——-构建工具

1.2 Vue两个核心点

1.2.1 响应式数据绑定
  • 当数据发生变化是,vue自动更新视图。
  • 它的原理是利用了 Object.definedProperty 中的setter/getter 代理数据, 监控对数据的操作。(这就是为什么vue不支持ie8 以及更早的ie浏览器的原因) 1.2.2 组合的视图组件
  • ui页面映射为组件书
  • 划分组件可维护、可重用、可测试

1.3 虚拟Dom

js的运行速度已经很快了,然而大量的DOM 操作就会变得很慢,但是前端本身就是要通过 JS处理DOM来更新视图数据的。这样在更新数据后会重新渲染页面,这样就造成在没有 改变数据的地方也重新渲染了DOM节点。这样性能方面就会很受影响。

利用在内存中生成与真实DOM与之对应的数据结构,这个在内存中生成的结构称之为虚拟DOM。 当数据发生变化时,能够智能的计算出重新渲染组件的最小代价并应用到DOM操作上。 vue就是利用了这一点。(vue 渲染组件的步骤图:)

二、MVVM模式

我们可能经常听说的有MVC模式和MVVN模式。 angularJS就是所谓的 MVC 模式的框架,model 、view、controller。 而vue 是 MVVM 模式的框架:

  • M: model (数据层,也就是指数据(前端是js))
  • V:view ( 也就是指DOM层 或用户界面 )
  • VM : view-model (处理数据和界面的中间层,也就是指Vue)

三、第一个Vue程序

代码语言:javascript
复制
<html>
<head>
    <meta charset="utf-8" />
    <script type="text/javascript" src='https://unpkg.com/vue'></script>
</head>
<body>
    <div id="app">
        {{ message }}
    </div>
</body>
<script>
    var app = new Vue({
        el: '#app',
        data: {
            message: 'Hello world!'
        }
    })
</script>
</html>

1)构造器 每个 Vue.js 应用都是通过构造函数 Vue 创建一个Vue的根实例启动:

代码语言:javascript
复制
var vm = new Vue({
  // 选项
})

2)属性与方法 每个 Vue 实例都会代理其 data 对象里所有的属性:

代码语言:javascript
复制
var data = { a: 1 }
var vm = new Vue({
  data: data
})
vm.a === data.a // -> true
// 设置属性也会影响到原始数据
vm.a = 2
data.a // -> 2
// ... 反之亦然
data.a = 3
vm.a // -> 3

除了 data 属性, Vue 实例暴露了一些有用的实例属性与方法。 这些属性与方法都有前缀 $,以便与代理的 data 属性区分。例如:

代码语言:javascript
复制
var data = { a: 1 }
var vm = new Vue({
  el: '#example',
  data: data
})
vm.$data === data // -> true
vm.$el === document.getElementById('example') // -> true
// $watch 是一个实例方法
vm.$watch('a', function (newVal, oldVal) {
  // 这个回调将在 `vm.a`  改变后调用
})

3)实例生命周期 每个 Vue 实例在被创建之前都要经过一系列的初始化过程。例如,实例需要配置数据 观测(data observer)、编译模版、挂载实例到 DOM ,然后在数据变化时更新 DOM 。 在这个过程中,实例也会调用一些 生命周期钩子 ,这就给我们提供了执行自定义逻辑的 机会。

代码语言:javascript
复制
<html>

<head>
    <meta charset="utf-8" />
    <script type="text/javascript" src='https://unpkg.com/vue'></script>
</head>

<body>
    <div id="app">
        {{ message }}
    </div>
</body>
<script>
    var app = new Vue({
        el: '#app',
        data: {
            message: 'Hello Vue!'
        },
        beforeCreate: function () {
            console.log("vue beforeCreate......")
        },
        created: function () {
            console.log("vue created......")
        },
        beforeMount: function () {
            console.log("vue beforeMount......")
        },
        mounted: function () {
            console.log("vue mounted......")
        },
        beforeUpdate: function () {
            console.log("vue beforeUpdate......")
        },
        updated: function () {
            console.log("vue updated......")
        },
        beforeDestroy: function () {
            console.log("vue beforeDestroy......")
        },
        destroyed: function () {
            console.log("vue destroyed......")
        }
    })
</script>

</html>

结果:

代码语言:javascript
复制
vue beforeCreate......
vue created......
vue beforeMount......
vue mounted......

谷歌浏览器控制台输入 app.message = 11111
vue beforeUpdate......
vue updated......

app.$destroy()
vue beforeDestroy......
vue destroyed......
undefined
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-08-16 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 一、Vue简介
    • 1.1 渐进式框架-Vue
      • 1.2 Vue两个核心点
        • 1.2.1 响应式数据绑定
      • 1.3 虚拟Dom
      • 二、MVVM模式
      • 三、第一个Vue程序
      相关产品与服务
      图数据库 KonisGraph
      图数据库 KonisGraph(TencentDB for KonisGraph)是一种云端图数据库服务,基于腾讯在海量图数据上的实践经验,提供一站式海量图数据存储、管理、实时查询、计算、可视化分析能力;KonisGraph 支持属性图模型和 TinkerPop Gremlin 查询语言,能够帮助用户快速完成对图数据的建模、查询和可视化分析。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档