本篇将简单介绍一下Vue.js,并在Node.js环境下搭建一个简单的Demo。
一、简介
我个人理解,Vue.js是一套前端视图层的框架,它只关心视图展示和数据绑定,它的一些语法与Angular 1非常相似,如果有Angular 1相关的使用经验,上手会非常快。
相比较其他的React、Angular 2等MVVM框架,它更加的轻量,效率也更高,也能更好的与其他库集成。
它拥有以下几个出色的特性:
当前最新的版本为2.1.4。后续也会在这个版本下演示Demo。
二、环境准备
下载安装Node.js环境,安装成功后在命令行窗口依次执行以下命令:
> npm install bower -g > npm install express-generator -g
安装完成后进入工程目录(随意新建一个目录),依次执行以下命令,创建一个名为vue-demo的项目:
> express vue-demo --view=ejs > cd vue-demo > npm install > bower init > bower install requirejs --save > bower install vue --save
所有命令执行成功后,在项目根目录手动增加一个名为.bowerrc文件,内容如下
{ "directory": "public/plugins/" }
为了后面显示的demo页面好看一点,再引入bootstrap。这步不是必须的
> bower install bootstrap --save
最终的目录结构如下
三、Hello World
按照惯例,学习一个新的语言,都要先问候一下我们这个精彩的世界。修改 views/index.ejs 文件内容
<!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>Index</title> <!-- Bootstrap --> <link href="plugins/bootstrap/dist/css/bootstrap.min.css" rel="stylesheet"> </head> <body> <div id="app" class="container"> <input type="text" v-model="message" /> <p>{{message}}</p> </div> <!-- requirejs main --> <script src="plugins/requirejs/require.js" data-main="javascripts/index.js"></script> </body> </html>
在 public/javascrips 目录里新建一个文件 index.js ,内容如下
/// <reference path="../plugins/requirejs/require.js" /> require.config({ baseUrl: "plugins", paths: { jquery: "jquery/dist/jquery.min", bootstrap: "bootstrap/dist/js/bootstrap.min", vue: "vue/dist/vue.min" } }); require(['jquery', 'bootstrap', 'vue'], function ($, bootstrap, Vue) { var vm = new Vue({ el: "#app", data: { message: "Hello world!" } }); });
在命令行窗口的项目目录下执行命令 npm start ,访问 http://localhost:3000/
修改文本框里的内容,下方文字也会跟着变化
这是一个简单的双向数据绑定的例子。通过Vue类型构造了一个根实例,分别给 el 属性赋值需要绑定的页面元素ID,给 data 属性赋值需要绑定的数据。在页面里,通过给 input 元素添加指令 v-model ,绑定到数据的message属性。在 p 元素里通过表达式 {{message}} 绑定message属性。这样页面就能直接展示绑定的数据内容,在改变 input 的内容时,也能同步改变下方文本内容。
四、属性、方法
通过Vue实例可以直接访问绑定的数据的属性。修改 index.js 文件内容:
require(['jquery', 'bootstrap', 'vue'], function ($, bootstrap, Vue) { var d = { message: "Hello world!" }; var vm = new Vue({ el: "#app", data: d }); // 属性代理 console.log('vm.message = ' + vm.message); console.log('vm.message === d.message? ' + (vm.message === d.message)); });
访问页面,查看浏览器控制台显示如下:
从上面的例子可以看到, vm 实例“代理”了绑定的数据对象,通过实例可以直接访问数据对象里的属性。
除了能“代理”数据对象, vm 实例也有一些内置属性和方法,这些属性和方法都有 $ 前缀。再修改 index.js 内容:
require(['jquery', 'bootstrap', 'vue'], function ($, bootstrap, Vue) { var d = { message: "Hello world!" }; var vm = new Vue({ el: "#app", data: d }); // 属性代理 console.log('vm.message = ' + vm.message); console.log('vm.message === d.message? ' + (vm.message === d.message)); console.log('vm.$data = ' + JSON.stringify(vm.$data)); console.log('vm.$data === d? ' + (vm.$data === d)); console.log('vm.$el = ' + vm.$el); console.log('vm.$el === div.#app? ' + (vm.$el === document.getElementById('app'))); // 内置方法 vm.$watch('message', function (oldVal, newVal) { console.log('oldVal is: ' + oldVal); console.log('newVal is: ' + newVal); }); });
刷新页面,查看控制台:
修改页面文本框的内容,查看控制台:
$watch:Vue实例监视属性变化的内置方法。当被监视的属性改变时,将会触发这个方法。
五、生命周期钩子
Vue也提供了在实例化时各个状态变化过程中触发的事件方法。修改 index.js 内容:
require(['jquery', 'bootstrap', 'vue'], function ($, bootstrap, Vue) { var d = { message: "Hello world!" }; var vm = new Vue({ el: "#app", data: d, beforeCreate: function () { console.log('beforeCreate is triggered.') }, created: function () { console.log('created is triggered.') }, beforeMount: function () { console.log('beforeMount is triggered.') }, mounted: function () { console.log('mounted is triggered.') }, beforeUpdate: function () { console.log('beforeUpdate is triggered.') }, updated: function () { console.log('updated is triggered.') }, beforeDestroy: function () { console.log('beforeDestroy is triggered.') }, destroyed: function () { console.log('destroyed is triggered.') } }); });
刷新页面,查看控制台:
修改文本框内容,查看控制台:
下面是完整的生命周期图示:
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,同时也希望多多支持小牛知识库!
本文向大家介绍vue.js入门教程之基础语法小结,包括了vue.js入门教程之基础语法小结的使用技巧和注意事项,需要的朋友参考一下 前言 Vue.js是一个数据驱动的web界面库。Vue.js只聚焦于视图层,可以很容易的和其他库整合。代码压缩后只有24kb。 以下代码是Vue.js最简单的例子, 当 input 中的内容变化时,p 节点的内容会跟着变化。 vue.js的基础语法 插入文本 插入ht
本文向大家介绍Javascript 基础---Ajax入门必看,包括了Javascript 基础---Ajax入门必看的使用技巧和注意事项,需要的朋友参考一下 Ajax 是现代Web 应用程序开发的一项关键工具。它让你能向服务器异步发送和接收数据,然后用 Javascript 解析。 Ajax 是 Asynchronous JavaScript and XML (异步JavaScript 与XML
本文向大家介绍javascript学习之json入门,包括了javascript学习之json入门的使用技巧和注意事项,需要的朋友参考一下 1. 什么是JSON JSON---Javascript Object Notation,前两个单词大家应该都认识,最后一个notation,是“记号、标记法”的意思,连在一起,便成了JSON。 它是一种轻量级的数据交换格式,是基于Javascript的一个子
本文向大家介绍Vue.JS入门教程之事件监听,包括了Vue.JS入门教程之事件监听的使用技巧和注意事项,需要的朋友参考一下 你可以使用 v-on 指令来绑定并监听 DOM 事件。绑定的内容可以是一个当前实例上的方法 (后面无需跟括号) 或一个内联表达式。如果提供的是一个方法,则原生的 DOM event 会被作为第一个参数传入,同时这个 event 会带有 targetVM 属性,指向触发该事件的
本文向大家介绍Vue.JS入门教程之列表渲染,包括了Vue.JS入门教程之列表渲染的使用技巧和注意事项,需要的朋友参考一下 你可以使用 v-repeat 指令来基于 ViewModel 上的对象数组渲染列表。对于数组中的每个对象,该指令将创建一个以该对象作为其 $data 对象的子 Vue 实例。这些子实例继承父实例的数据作用域,因此在重复的模板元素中你既可以访问子实例的属性,也可以访问父实例的属
本文向大家介绍Vue.JS入门教程之处理表单,包括了Vue.JS入门教程之处理表单的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Vue.JS表单处理的相关内容,供大家参考,具体内容如下 基本用法 惰性更新 默认情况下,v-model 会在每个 input 事件之后同步输入的数据。你可以添加一个 lazy 特性,将其改变为在 change 事件之后才进行同步。 转换为数字 如果你希望