Vue入门2
欢迎转载,转载请注明出处。
前言
学习本系列Vue知识,需要结合本系列的一些demo。你可以查看我的 Github 或者直接下载 ZIP包 。
建议学习本系列之前已经会一个其他的前端框架,了解计算属性,数据绑定,模板语言等。零基础的话,看本教程可能不太适合。
上一篇文章已经讲了前六个demo。
七、Vue实例
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue-demos</title>
<script src="../vue.js"></script>
</head>
<body>
<!--
Vue实例
-->
<div id="app">
<p>{{ message }}</p>
<button v-on:click="sayHello">sayHello</button>
</div>
<script>
//每个 Vue应用都是通过构造函数 Vue 创建一个 Vue的根实例 启动的 var app = new Vue({});
//在实例化 Vue 时,需要传入一个选项对象,它可以包含数据data、模板template、挂载元素el、方法methods、生命周期钩子等选项
var app = new Vue({
el: '#app',
data: { //每个 Vue 实例都会代理其 data 对象里所有的属性
message: 'Hello Vue' //app.message = app.data.message
},
methods: {
sayHello: function(){
alert('hello');
}
},
created: function(){ //实例生命周期的不同阶段,如created、 mounted、 updated 、destroyed 。钩子的 this 指向调用它的 Vue 实例。一些用户可能会问 Vue.js 是否有“控制器”的概念?答案是,没有。组件的自定义逻辑可以分布在这些钩子中。
// this 指向 vm 实例
console.log(this.message + '实例被创建');
}
});
</script>
</body>
</html>

八、注册全局组件
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue-demos</title>
<script src="../vue.js"></script>
</head>
<body>
<!--
全局组件
在Vue里,一个组件实质上是一个拥有预定义选项的一个Vue实例。
要注册一个全局组件,你可以使用 Vue.component(tagName, options)
-->
<div id="app">
<!-- 引用组件 -->
<my-component></my-component>
</div>
<script>
// 注册组件。要确保在初始化根实例之前注册了组件
Vue.component('my-component', {
template: '<div>A custom component!</div>'
});
// 创建根实例
var app = new Vue({
el: '#app'
});
</script>
</body>
</html>

九、注册局部组件
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue-demos</title>
<script src="../vue.js"></script>
</head>
<body>
<!--
局部注册组件
不必在全局注册每个组件。通过使用组件实例选项注册,可以使组件仅在另一个实例/组件的作用域中可用
-->
<div id="app">
<!-- 引用组件 -->
<my-component></my-component>
</div>
<script>
// 注册局部组件
var Child = {
template: '<div>A child component!</div>'
}
// 创建根实例.并调用局部组件
var app = new Vue({
el: '#app',
components: {
'my-component': Child
}
});
</script>
</body>
</html>

十、props传递数据
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue-demos</title>
<script src="../vue.js"></script>
</head>
<body>
<!--
父组件通过 props 向下传递数据给子组件,子组件通过 events 给父组件发送消息
prop 是单向绑定的:当父组件的属性变化时,将传导给子组件。
父组件使用 props 把数据传给子组件,子组件需要显式地用 props 选项 声明 “prop”:
-->
<div id="app">
<!-- 引用组件 -->
<child message="hello!"></child>
</div>
<script>
Vue.component('child', {
// 声明父组件的属性,props。然后在本子组件中就可以使用这个属性。
props: ['message'],
template: '<span>{{ message }}</span>'
}) var app = new Vue({
el: '#app'
});
</script>
</body>
</html>

十一、自定义事件events
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>vue-demos</title>
<script src="../vue.js"></script>
</head>
<body>
<!--
父组件使用 props 把数据传给子组件,但如果子组件要把数据传递回去,那就是自定义事件!
自定义事件也是使用v-on绑定。
使用 $on(eventName) 监听事件
使用 $emit(eventName) 触发事件 本例在app实例里定义了事件changeMsg().在子组件中去触发这个事件。从而实现子组件的数据传递到父组件
--> <div id="app">
<p>Message: {{message}}</p>
<child></child>
</div> <template id="temp">
<div>
<input v-model="msg" placeholder="please input your message!" />
<button @click="test(msg)">change message</button>
</div>
</template> <script>
Vue.component('child', {
//指定模板为id为"temp"标签
template: "#temp",
//定义模板中初始化的值,data应该是一个函数
data: function() {
return {
msg: "hello",
}
},
methods: {
//当点击按钮时会触发的事件(这个事件中会调用自定义的事件)
test: function(msg){
console.log('be click' + msg);
app.$emit('changeMsg', msg);
}
} }) var app = new Vue({
el: '#app',
//初始化messages数组
data: {
message: 'hello',
}
}); //自定义事件
app.$on('changeMsg', function (msg) {
console.log('我是自定义事件')
app.message = msg;
})
</script>
</body>
</html>

Vue入门2的更多相关文章
- wepack+sass+vue 入门教程(三)
十一.安装sass文件转换为css需要的相关依赖包 npm install --save-dev sass-loader style-loader css-loader loader的作用是辅助web ...
- wepack+sass+vue 入门教程(二)
六.新建webpack配置文件 webpack.config.js 文件整体框架内容如下,后续会详细说明每个配置项的配置 webpack.config.js直接放在项目demo目录下 module.e ...
- wepack+sass+vue 入门教程(一)
一.安装node.js node.js是基础,必须先安装.而且最新版的node.js,已经集成了npm. 下载地址 node安装,一路按默认即可. 二.全局安装webpack npm install ...
- vue入门学习(基础篇)
vue入门学习总结: vue的一个组件包括三部分:template.style.script. vue的数据在data中定义使用. 数据渲染指令:v-text.v-html.{{}}. 隐藏未编译的标 ...
- VUE 入门笔记
前端的MVVM概念今年来也算是如火如荼,了解完 MVVM的概念,也该找个去尝试下 首先我先试了下 国内小而美的 VUE 试着照着文档敲出入门文件,内容都在注释里 <!doctype html&g ...
- Vue 入门指南 JS
Vue 入门指南 章节导航 英文:http://vuejs.org/guide/index.html 介绍 vue.js 是用来构建web应用接口的一个库 技术上,Vue.js 重点集中在MVVM模式 ...
- Vue学习记录第一篇——Vue入门基础
前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...
- parcel+vue入门
一.parcel简单使用 npm install -D parcel-bundler npm init -y (-y表示yes,跳过项目初始化提问阶段,直接生成package.json 文件.) Pa ...
- Vue入门基础
前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...
- 学习Vue 入门到实战——学习笔记
闲聊: 自从进了现在的公司,小颖就再没怎么接触vue了,最近不太忙,所以想再学习下vue,就看了看vue相关视频,顺便做个笔记嘻嘻. 视频地址:Vue 入门到实战1.Vue 入门到实战2 学习内容: ...
随机推荐
- SpringCloud高可用和高并发
1 高可用 什么是高可用:(High Availability)在一个长时间内服务不受影响.通俗的讲就是,一个机器挂掉的时候,有其他机器可以继续提供同样的服务. 如何实现高可用:冗余+自动故障转移.冗 ...
- 星系炸弹-2015省赛C语言A组第二题
星系炸弹 在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标.每个炸弹都可以设定多少天之后爆炸.比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸. ...
- Graveyard(poj3154)
Graveyard Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 1289 Accepted: 660 Specia ...
- java中递归实现复制多级文件夹
常见的流的用法 递归实现复制多级文件夹 FileInputStream & FileOutputStream String content = null;//用来储存解码后的byte数组 in ...
- java工具包一:日期处理
作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7846812.html 邮箱:moyi@moyib ...
- DRF序列化/反序列化
反序列化(不推荐版):两个字段 一个为正序准备,一个为反序准备重写create update方法 1. 确定数据结构: 自己定义key book_obj = { "title": ...
- avalonjs 中的if else实现的几种方法
在学习avalonjs的过程中,发现模板中并没有if else这样的写法,不像tempalte ejs这些,所以总结了三种方法来实现,仅供在使用avalonjs的同学参考,主要是通过ms-if 表达式 ...
- 洛谷P4396 [AHOI2013]作业(树套树)
题意 题目链接 Sol 为什么一堆分块呀..三维数点不应该是套路离线/可持久化+树套树么.. 亲测树状数组套权值线段树可过 复杂度\(O(nlog^2n)\),空间\(O(nlogn)\)(离线) # ...
- event.stopPropagation与event.preventDefault的区别
1.event.stopPropagation 停止事件的传播,阻止它被分配到其它Dom节点.但是不能阻止同一Dom节点上的其它事件句柄被调用. 注:不同Dom节点的事件必须是一致的.如父节点和子节点 ...
- paste 命令
Linux paste命令用于合并文件的列. paste指令会把每个文件以列对列的方式,一列列地加以合并. 语法: paste [-s][-d <间隔字符>][--help][--vers ...