vue组件总结(三)
一、什么是组件
组件(component)是Vue最强大的功能之一。组件可以扩展HTML元素,封装可重用的代码,根据项目需求,抽象出一些组件,每个组件里包含了展现、功能和样式。每个页面,根据自己的需要,使用不同的组件来拼接页面。这种开发模式使得前端页面易于扩展,且灵活性高,而且组件之间也实现了解耦。
在Vue里,一个组件本质上是一个拥有预定义选项的一个Vue实例。组件是一个自定义元素或称为一个模块,包括所需的模板、逻辑和样式。在HTML模板中,组件以一个自定义标签的形式存在,起到占位符的功能。通过Vue.js的声明式渲染后,占位符将会被替换为实际的内容。
二、注册组件
组件注册包括全局注册和局部注册两种
- 调用
Vue.component()
注册组件时,组件的注册是全局的,这意味着该组件可以在任意Vue示例下使用。(全局注册的行为必须在根Vue实例创建之前发生) - 如果不需要全局注册,或者是让组件使用在其它组件内,可以用选项对象的components属性实现局部注册。(局部注册组件在子组件中不可用)
【全局组件】要注册一个全局组件,可以使用Vue.component(tagName,option),组件在注册之后,便可以在父实例的模块中以自定义元素<my-component></my-component>的形式使用,实例如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>全局组件</title>
<script src="../node_modules/vue/dist/vue.js"></script>
<style type="text/css">
.container{
width: 200px;
height: 300px;
border: 2px solid blue;
}
.container h2{
font-size: 30px;
font-style: normal;
}
</style>
</head>
<body>
<div id="app">
<!--使用组件,全局组件可以多次使用-->
<my-component></my-component>
</div>
<div id="app2">
<!--使用组件,全局组件可以多次使用-->
<my-component></my-component>
<my-component2></my-component2>
</div>
<!--定义组件的视图-->
<template id="demo3">
<h1 style="color:red">我是选项模板3</h1>
</template>
<!--定义组件的视图-->
<script type="x-template" id="demo4">
<div class="container">
<h1 style="color:red">我是script标签模板4</h1>
<h2>我是script标签模板</h2>
</div>
</script> <script>
//全局注册组件,全局组件可以多次使用
Vue.component("my-component",{
template:"#demo3"
});
//全局注册组件,全局组件可以多次使用
Vue.component("my-component2",{
template:"#demo4"
});
var vm1 = new Vue({
el: "#app"
});
var vm2 = new Vue({
el: "#app2"
})
</script>
</body>
</html
运行效果如下所示:
【局部注册】通过使用组件实例选项component注册,可以使组件仅在另一个实例或者组件的作用域中可用,实例如下所示:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>局部组件</title>
<script src="../node_modules/vue/dist/vue.js"></script>
<style type="text/css">
.container{
width: 200px;
height: 300px;
border: 2px solid blue;
}
.container h2{
font-size: 30px;
font-style: normal;
}
</style>
</head>
<body> <template id="demo1">
<h1 style="color:red">我是局部组件的布局模板1</h1>
</template> <script type="x-template" id="demo2">
<div class="container">
<h1 style="color:red">我是script标签构建的布局模板</h1>
<h2>我是script标签模板</h2>
</div> </script> <div id="app1">
<my-component1></my-component1>
<my-component2></my-component2>
</div>
<div id="app2">
<!--无法在app2这里使用,因为是子组件是在app2中局部注册的-->
<my-component1></my-component1>
<my-component2></my-component2>
</div>
<script>
//子组件1
var child1 = {
template:"#demo1"
};
//子组件2
var child2 = {
template:"#demo2"
};
var vm1 = new Vue({
el: "#app1",
components:{
//注册子组件,<my-component1>和<my-component2>只能在app1使用
"my-component1":child1,
"my-component2":child2
}
});
var vm2 = new Vue({
el: "#app2"
})
</script>
</body>
</html>
运行效果如下所示:
三、组件之间传值
3.1. 父组件向子组件传值
子组件在props中创建一个属性,用以接收父组件传过来的值
在父组件中注册子组件;
在子组件标签中添加子组件props中创建的属性;
把需要传给子组件的值赋给该属性
实例如下所示:
父组件:
<template>
<!-- 父组件 -->
<div id="app">
父组件:
<input type="text" v-model="name">
<!-- 引入子组件 -->
<child :inputName="name"></child>
</div>
</template> <script type="text/ecmascript-6">
import child from './child'
export default {
components: {
child
},
data () {
return {
name: ''
}
}
}
</script> <style lang="stylus" rel="stylesheet/stylus" scoped> </style>
子组件:
<template>
<div>
<!--子组件-->
子组件:
<span>{{inputName}}</span>
</div>
</template> <script type="text/ecmascript-6">
export default {
/* 接受父组件 */
props: {
inputName: String,
required: true
} }
</script> <style lang="stylus" rel="stylesheet/stylus" scoped> </style>
运行效果如下所示:
3.2.子组件向父组件传值
子组件中需要以某种方式(如点击事件)的方法来触发一个自定义的事件;
- 将需要传的值作为$emit的第二个参数,该值将作为实参传给响应事件的方法;
3.在父组件中注册子组件并在子组件标签上绑定自定义事件的监听。
实例如下所示:
子组件:
<template>
<div id="app">
子组件:
<span>{{childValue}}</span>
<!-- 定义一个子组件传值的方法 -->
<input type="button" value="点击触发" @click="childClick">
</div>
</template> <script type="text/ecmascript-6">
export default {
data () {
return {
childValue: '我是子组件的数据'
}
},
methods: {
childClick () {
console.log('childClick')
// childByValue是在父组件on监听的方法
// 第二个参数this.childValue是需要传的值
this.$emit('childByValue', this.childValue)
}
}
}
</script> <style lang="stylus" rel="stylesheet/stylus" scoped> </style>
父组件:
<template>
<div>
父组件:
<span>{{name}}</span>
<br>
<br>
<!-- 引入子组件 定义一个on的方法监听子组件的状态-->
<child-component v-on:childByValue="childByValue"></child-component>
</div>
</template> <script type="text/ecmascript-6">
import childComponent from './childComponent'
export default {
components: {
childComponent
},
data () {
return {
name: ''
}
},
methods: {
childByValue: function (childValue) {
// childValue就是子组件传过来的值
this.name = childValue
console.log(this.name)
}
}
}
</script> <style lang="stylus" rel="stylesheet/stylus" scoped> </style>
运行效果如下所示:
vue组件总结(三)的更多相关文章
- Vue组件的三种调用方式
最近在写fj-service-system的时候,遇到了一些问题.那就是我有些组件,比如Dialog.Message这样的组件,是引入三方组件库,比如element-ui这样的,还是自己实现一个?虽然 ...
- 二、Vue组件(component):组件的相互引用、通过props实现父子组件互传值
一.组件各部分说明及互相引用 1.一个vue组件由三个部分组成 Template 只能存在一个根元素 2.Script 3.Style scoped:样式只在当前组件内生效 1.1 组件的基本引用代码 ...
- 在html中使用vue组件
最近在维护公司的项目,当我拿到项目时,发现他用了vue. 但是~~仅仅是引用vue.js文件,整体的架构还是html那种,没有用webpack! 当时觉得~哇~原来还可以这样! 然后了解了业务逻辑和代 ...
- 第七十篇:Vue组件的使用
好家伙, 1.vue的组件化开发 1.1.什么是组件? 组件是对UI结构的复用, vue是一个支持组件化开发的前端框架, vue中规定:组件的后缀名是.vue 例如:App.vue文件本质上就是一个v ...
- Vue (三) --- Vue 组件开发
------------------------------------------------------------------好心情,会让你峰回路转. 5. 组件化开发 5.1 组件[compo ...
- 三: vue组件开发及自动化工具vue-cli
一: 组件化开发 1 组件 1: 组件(Component)是自定义封装的功能.在前端开发过程中,经常出现多个网页的功能是重复的,而且很多不同的网站之间,也存在同样的功能. 2: 什么是组件 而在网页 ...
- day 83 Vue学习三之vue组件
本节目录 一 什么是组件 二 v-model双向数据绑定 三 组件基础 四 父子组件传值 五 平行组件传值 六 xxx 七 xxx 八 xxx 一 什么是组件 首先给大家介绍一下组件(componen ...
- Vue系列(三):组件及数据传递、路由、单文件组件、vue-cli脚手架
上一篇:Vue系列(二):发送Ajax.JSONP请求.Vue生命周期及实例属性和方法.自定义指令与过渡 一. 组件component 1. 什么是组件? 组件(Component)是 Vue.js ...
- Vue框架(三)——Vue项目搭建和项目目录介绍、组件、路由
Vue项目环境搭建 1) 安装node,在官网下载好,然后在本地安装 官网下载安装包,傻瓜式安装:https://nodejs.org/zh-cn/ 2) 换源安装cnpm >: npm ins ...
- 黑马vue---56-58、vue组件创建的三种方式
黑马vue---56-58.vue组件创建的三种方式 一.总结 一句话总结: 不论是哪种方式创建出来的组件,组件的 template 属性指向的模板内容,必须有且只能有唯一的一个根元素 1.使用 Vu ...
随机推荐
- 4.Windows应急响应:勒索病毒
0x00 前言 勒索病毒,是一种新型电脑病毒,主要以邮件.程序木马.网页挂马的形式进行传播.该病毒性质恶劣. 危害极大,一旦感染将给用户带来无法估量的损失.这种病毒利用各种加密算法对文件进行加密,被感 ...
- 20169201 实验三 敏捷开发与XP实践报告
敏捷开发与XP介绍 敏捷开发(Agile Development)是一种以人为核心.迭代.循序渐进的开发方法."敏捷流程"是一系列价值观和方法论的集合.从2001年开始,一些软件界 ...
- ADO.Net事务处理
SQL Server中的事务可以将多个数据库增删改查操作合并为单个工作单元,在操作过程中任何部分出错都可以滚回已经执行的所有更改.ADO.Net中也提供了事务处理功能,通过ADO.net事务,可以将多 ...
- 第一个Python工程
创建你的第一个Python程序 如果你曾经很熟悉visual studio的工作方式.可能对python不习惯. 工程通常只与你使用的IDLE有关系.这些工具习惯将文档,编译,测试集成一体.所以就存在 ...
- SQL Server2012如何打开2016的profiler文件
SQL Server 2012如何打开2016的profiler文件 作者:markjiang7m2 原文地址:https://www.cnblogs.com/markjiang7m2/p/10980 ...
- ios json转model的简单现实
在android开发中,可用第三方的转换库如gson等.当然在ios也有一些库如MJExtensiond等.在这里,我简单实现一下. 一.先建一个model并且继承NSObject,代码如下: cla ...
- js和css文件位置对页面性能的影响
翻译了一篇Performance上的关于页面性能的文章<DecIPhering the critical rendering path>,原文在这里.需要进一步整理和了解有关js.css等 ...
- saltstack执行结果存储到MySQL
saltstack执行结果保存到MySQL中,以便进行命令安全审计必须是python2.7以上的环境安装相关模块ubuntu系统安装 apt-get install -y python-mysqldb ...
- Hive_hdfs csv导入hive demo
1 create csv file.student.csv 4,Rose,M,78,77,76 5,Mike,F,99,98,98 2 put it to hdfs. # hdfs dfs -put ...
- leetcode 91. 解码方法
题目描述: 一条包含字母 A-Z 的消息通过以下方式进行了编码: 'A' -> 1 'B' -> 2 ... 'Z' -> 26 给定一个只包含数字的非空字符串,请计算解码方法的总数 ...