vue官方文档

知识储备

es6语法补充

  • let

    使用 var 声明的变量的作用域是全局。

    {
    var a = 1;
    }
    console.info(a); //

    例1:

    var arr = [];
    for (var i = 0; i < 10; i++) {
    arr[i] = function(){
    console.info(i);
    }
    }
    arr[6]();// var arr = [];
    for (let i = 0; i < 10; i++) {
    arr[i] = function(){
    console.info(i);
    }
    }
    arr[6]();//

    例2:

    let 声明的变量,它的作用域是定义时所在的块内。

    {
    let b = 2;
    }
    console.info(b); // Uncaught ReferenceError: b is not defined

    例:

    let 声明的变量不能重复声明。

    {
    let c = 3;
    let c = 4; // Uncaught SyntaxError: Identifier 'c' has already been declared
    }

    例:

  • const

    const 声明的变量需要立即初始化,不能重新赋值。

    const a = 1;
    a = 2; // Uncaught TypeError: Assignment to constant variable.

    例:

  • 模板字符串

    var a = 1,
    b = 2;
    var str = `a=${a},b=${b}`;
    console.info(str); // a=1,b=2

    例:

  • 箭头函数

    普通函数和箭头函数的定义对比。

    // 普通函数,无参
    var f1 = function(){
    return '123';
    } // 箭头函数,无参
    var f2 = () => '123';
    console.info(f2()); // // 普通函数,有参
    var f3 = function(a, b) {
    return a;
    }
    // 箭头函数,有参
    var f4 = (a, b) => a + b;
    console.info(f4(1, 2)); //

    例:

    普通函数和箭头函数使用 this 的对比。

    var person1 = {
    name: '张三',
    fav: function() {
    // 使用普通函数时,this指向的是当前调用对象。
    console.info(this); // {name: "张三", fav: ƒ}
    console.info(this.name); // 张三
    }
    }
    person1.fav(); var person2 = {
    name: '张三',
    fav: () => {
    // 使用箭头函数时,this指向的是定义时所在的变量,在这里也就是window。
    console.info(this); // Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, frames: Window, …}
    console.info(this.name); // (空字符串)
    }
    }
    person2.fav();

    例:

    普通函数和箭头函数使用arguments的对比。

    var func1 = function() {
    console.info(arguments);
    } func1(1, 2, 3); // Arguments(3) [1, 2, 3, callee: ƒ, Symbol(Symbol.iterator): ƒ] // 使用箭头函数时,arguments不能使用。
    var func2 = () => {
    console.info(arguments);
    } func2(1, 2, 3); // Uncaught ReferenceError: arguments is not defined

    例:

  • 对象的单体模式

    var person1 = {
    name: '张三',
    fav: function() {
    console.info(this);
    console.info(this.name);
    }
    }
    // person2.fav等价于person1.fav
    var person2 = {
    name: '张三',
    fav() {
    console.info(this); // {name: "张三", fav: ƒ}
    console.info(this.name); // 张三
    }
    } person2.fav()

    例:

  • 面向对象

    // 构造函数创建对象
    function Animal1(name,age) {
    this.name = name;
    this.age = age;
    }
    Animal1.prototype.showName= function(){
    console.info(this.name);
    } var dog1 = new Animal1('小黄',3);
    console.info(dog1); // Animal1 {name: "小黄", age: 3}
    dog1.showName(); // 小黄 // class创建对象
    class Animal2{
    constructor(name,age){
    this.name = name;
    this.age = age;
    }
    showName(){
    console.info(this.name);
    }
    } var dog2 = new Animal2('小黑',2);
    console.info(dog2); // Animal2 {name: "小黑", age: 2}
    dog2.showName(); // 小黑

    例:

npm操作

  • 初始化

    npm init
  • 安装模块

    以安装 jquery 为例:

    npm install jquery@[版本号,不写默认最高版本] --save
    npm install jquery@[版本号,不写默认最高版本] --save-dev #保存开发版本

    如果 install 失败,可先尝试 rebuild 操作如下:

    npm rebuild
  • 卸载模块

    以卸载 jquery 为例:

    npm uninstall jquery
  • 安装cnpm

    $ npm install -g cnpm --registry=https://registry.npm.taobao.org

Vue实例

创建一个Vue实例

每个 Vue 应用都是通过用 Vue 函数创建一个新的 Vue 实例开始的:

var vm = new Vue({
// 选项
})

当一个 Vue 实例被创建时,它向 Vue 的响应式系统中加入了其  data 对象中能找到的所有的属性。当这些属性的值发生改变时,视图将会产生“响应”,即匹配更新为新的值。

// 我们的数据对象
var data = { a: 1 } // 该对象被加入到一个 Vue 实例中
var vm = new Vue({
data: data
}) // 获得这个实例上的属性
// 返回源数据中对应的字段
vm.a == data.a // => true // 设置属性也会影响到原始数据
vm.a = 2
data.a // => 2 // ……反之亦然
data.a = 3
vm.a // => 3

当这些数据改变时,视图会进行重渲染。值得注意的是只有当实例被创建时 data 中存在的属性才是响应式的。也就是说如果你添加一个新的属性,比如:

vm.b = 'hi'

那么对 b 的改动将不会触发任何视图的更新。如果你知道你会在晚些时候需要一个属性,但是一开始它为空或不存在,那么你仅需要设置一些初始值。比如:

data: {
newTodoText: '',
visitCount: 0,
hideCompletedTodos: false,
todos: [],
error: null
}

这里唯一的例外是使用  Object.freeze() ,这会阻止修改现有的属性,也意味着响应系统无法再追踪变化。

var obj = {
foo: 'bar'
} Object.freeze(obj) new Vue({
el: '#app',
data: obj
})
<div id="app">
<p>{{ foo }}</p>
<!-- 这里的 `foo` 不会更新! -->
<button v-on:click="foo = 'baz'">Change it</button>
</div>

除了数据属性,Vue实例还暴露了一些有用的实例属性与方法。它们都有前缀  $ ,以便与用户定义的属性区分开来。例如:

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 (newValue, oldValue) {
// 这个回调将在 `vm.a` 改变后调用
})

实例生命周期钩子

每个 Vue 实例在被创建时都要经过一系列的初始化过程——例如,需要设置数据监听、编译模板、将实例挂载到 DOM 并在数据变化时更新 DOM 等。同时在这个过程中也会运行一些叫做生命周期钩子的函数,这给了用户在不同阶段添加自己的代码的机会。

比如 created 钩子可以用来在一个实例被创建之后执行代码:

new Vue({
data: {
a: 1
},
created: function () {
// `this` 指向 vm 实例
console.log('a is: ' + this.a)
}
})
// => "a is: 1"

也有一些其它的钩子,在实例生命周期的不同阶段被调用,如  mounted 、 updated  和  destroyed 。生命周期钩子的  this 上下文指向调用它的 Vue 实例。

注意:不要在选项属性或回调上使用箭头函数,比如  created: () => console.log(this.a)  或  vm.$watch('a', newValue => this.myMethod()) 。因为箭头函数是和父级上下文绑定在一起的, this 不会是如你所预期的 Vue 实例,经常导致  Uncaught TypeError: Cannot read property of undefined 或  Uncaught TypeError: this.myMethod is not a function 之类的错误。

生命周期图示

下图展示了实例的生命周期。你不需要立马弄明白所有的东西,不过随着你的不断学习和使用,它的参考价值会越来越高。

前端框架之Vue(1)-第一个Vue实例的更多相关文章

  1. 前端框架Vue------>第一天学习、Vue学习的路径、Vue官网(1)

    文章目录 1.学习目标 2.前端知识体系 2.1 前端三要素 2.2.MVVM 3.第一个Vue程序 4.Vue实例的生命周期 vue的官方文档:https://cn.vuejs.org/ 1.学习目 ...

  2. 【vue】创建一个vue前端项目,编译,发布

    npm: Nodejs下的包管理器. webpack: 它主要的用途是通过CommonJS的语法把所有浏览器端需要发布的静态资源做相应的准备,比如资源的合并和打包. vue-cli: 用户生成Vue工 ...

  3. 使用vue cli3新建一个vue项目

    写在最前 虽然身为一个java后端工作者,前端还是要沾点的,基于vue的火热,所以平常的工作中项目前端基本都是vue.这次就主要讲一讲vue项目的创建,并从vue的安装开始讲起,附带上我之前安装使用时 ...

  4. 安装Vue和创建一个Vue脚手架项目

    首先 安装node.js,安装成功可以在控制台输入[node --version ]查看node的版本,因为安装了node会自带npm所以我们可以用 [npm --version]查到npm版本  如 ...

  5. 如何利用vue脚手架创建一个vue项目

    1.安装node.js 2.打开命令行查看下npm和node是否都安装好 node -v npm -v 3.安装淘宝镜像cnpm $ npm install -g cnpm --registry=ht ...

  6. React 还是 Vue: 你应该选择哪一个Web前端框架?

    学还是要学的,用的多了,也就有更多的认识了,开发中遇到选择的时候也就简单起来了. 本文作者也做了总结: 如果你喜欢用(或希望能够用)模板搭建应用,请使用Vue    如果你喜欢简单和“能用就行”的东西 ...

  7. 基于Vue.js的uni-app前端框架结合.net core开发跨平台project

    一.由来 最近由于业务需要要开发一套公益的APP项目,因此结合所给出的需求最终采用uni-app这种跨平台前端框架以及.netcore快速搭建我们的项目,并且能做到一套代码跨多个平台. 当然在前期技术 ...

  8. Vue.js 学习笔记 第2章 数据绑定和第一个Vue应用

    本篇目录: 2.1 Vue实例与数据绑定 2.2 指令与事件 2.3 语法糖 学习任何一种框架,从一个Hello World应用开始是最快了解该框架特性的途径. 我们先从一段简单的HTML代码开始,感 ...

  9. Vue(一) 数据绑定和第一个Vue应用

    学习 Vue.js 最有效的方法是查看官网文档 数据绑定和第一个Vue应用 先从一段简单的 HTML 代码开始,感受 Vue.js 最核心的功能. <!DOCTYPE html> < ...

随机推荐

  1. tomcat如何在server.xml中配置contexts

    https://tomcat.apache.org/tomcat-8.5-doc/deployer-howto.html#A_word_on_Contexts 例如你的程序 名字是hello端口是80 ...

  2. js中parseInt和Number

    昨天在项目中遇到一个问题,有关字符串准换成数字的问题,具体如下: 页面中<input type="number" id="bankNum" ng-mode ...

  3. 我所知道的几种display:table-cell的应用

    .outer span {  display: table-cell; } 一.display:table-cell属性简述 display:table-cell属性指让标签元素以表格单元格的形式呈现 ...

  4. 壁虎书2 End-to-End Machine Learning Project

    the main steps: 1. look at the big picture 2. get the data 3. discover and visualize the data to gai ...

  5. db2 reorg table failed处理

    概要: 当对一个表的结构进行改变后,需要reorg表,重新组织其目录统计信息,为数据库的访问计划提供信息,以便高效执行对其的操作. 对表作reorg操作,发生错误,通过db2 "? sql0 ...

  6. {MySQL完整性约束}一 介绍 二 not null与default 三 unique 四 primary key 五 auto_increment 六 foreign key 七 作业

    MySQL完整性约束 阅读目录 一 介绍 二 not null与default 三 unique 四 primary key 五 auto_increment 六 foreign key 七 作业 一 ...

  7. Codeforces 677D - Vanya and Treasure - [DP+优先队列BFS]

    题目链接:http://codeforces.com/problemset/problem/677/D 题意: 有 $n \times m$ 的网格,每个网格上有一个棋子,棋子种类为 $t[i][j] ...

  8. [No0000167]CPU内部组成结构及指令执行过程

    计算机的基本硬件系统由运算器.控制器.存储器和输入.输出设备五大部件组成.运算器和控制器等部件被集成在一起统称为中央处理单元(Central Processing Unit,CPU). CPU的功能 ...

  9. [No000012F]WPF(7/7) - 样式,触发器和动画

    WPF Tutorial : Beginning [^] WPF Tutorial : Layout-Panels-Containers & Layout Transformation [^] ...

  10. Oracle分析函数大全

    分析函数又叫开窗函数,OLAP函数等,因为有人问我用过开窗函数没,呵,什么是开窗函数,从来没听过,难道是分析函数么.哈哈,最后还真是分析函数哦!用过的东西别名也应该知道,赶上这么个事,就剽窃一眼Ora ...