vue学习笔记(七)组件
前言
在前面vue的一些博客中,我们几乎将vue的基础差不多学习完了,而从本篇博客开始将会进入到vue的另一个阶段性学习,本篇博客的内容在以后的vue项目中占很大的比重,所以小伙伴们需要认真学习,本篇博客的内容也比较简单,看过我博客的人都知道我所写的每一篇博客都是非常的详细的,所以大家不要担心学不会。我会尽量将所学的知识讲解的通俗易懂,让大家学习起来更加快乐,那么一起来看看吧!
本章目标
- 学会使用全局组件和局部组件
- 学会ref引用
初识组件
解释:组件系统是 Vue 的另一个重要概念,因为它是一种抽象,允许我们使用小型、独立和通常可复用的组件构建大型应用。仔细想想,几乎任意类型的应用界面都可以抽象为一个组件树
组件通常可以用来制作单页应用程序(SPA)
组件的话我们主要分为两类,一种是局部组件,一种是全局组件,接下来我会介绍这两种组件
全局组件
全局组件毫无疑问,肯定是很多地方都可以访问的了,
语法:
Vue.component('组件名',{
template:'模板'
})
这是最简单定义全局组件的语法,接下来带大家简单入门一下全局组件
(1)全局组件注册方式一
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>全局组件注册方式一</title>
</head>
<body>
<div id="app">
<t1></t1>
</div>
<div id="demo">
<t1></t1>
</div>
<script type="text/template" id="template1">
<div>这是一个组件</div>
</script>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
Vue.component('t1',{
template:'#template1'
})
let vm=new Vue({
el:'#app'
})
let d=new Vue({
el:'#demo'
})
</script>
</body>
</html>
首先我们使用script标签来定义模板然后将模板在组件中注册,在这里我们定义了两个vue实例,发现在demo和app中都可以使用,证明全局组件注册成功了,这是定义组件的第一种方法,接下来我们学习第二种
(2)全局组件注册方式二
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<div id="app">
<temp></temp>
</div>
<template id="template1">
<div>这是一个组件</div>
</template>
<div id="demo">
<temp></temp>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
Vue.component('temp',{
template:'#template1'
})
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ }
})
let app=new Vue({
el:'#demo'
})
</script>
</body>
</html>
第二种方法我们直接使用vue提供的template标签定义模板然后再组件中注册就可以了,
(3)全局组件注册方式三
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<div id="app">
<my-compent></my-compent>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
Vue.component('myCompent',{
template:'<div>这是第三种定义组件的方法</div>'
})
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ } }) </script>
</body>
</html>
这是第三种定义全局组件的方法,三种方法中都可以使用,主要看个人习惯,反正我是比较喜欢第三种,全局组件注册讲到这里就结束了,接下来主要讲解局部组件祖册。
局部组件
局部组件的话当然是定义在vue实例里面定义的了,局部组件只在当前vue实例中有效
(1)局部组件注册
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>局部组件注册</title>
</head>
<body>
<div id="app">
<hello></hello>
<!--<hi></hi>-->
</div>
<div id="demo">
<hi></hi>
<!--<hello></hello>-->
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm1=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ },
components:{
'hello':{
template:'<div>我叫hello,你叫什么</div>'
}
}
})
let vm2=new Vue({
el:'#demo',
components:{
'hi':{
template:'<div>我叫hi,你叫什么</div>'
}
}
})
</script>
</body>
</html>
结果的话我就不贴出来了,大家可以尝试一下,如果我们在app中使用hi组件或者在demo中使用hello组件的话,vue将会给出警告的,因为我们注册的是局部组件,所以无法使用。
ref引用
在介绍ref引用之前,我想带大家实现一个小demo,需求是这样的,页面上共有四个按钮分别为红,黄,绿,蓝,当我们点击某个按钮的时候就显示对应的颜色,如下图所示
当我们点击红色的时候,显示红色,依次类推,那就由我带大家实现这个小demo吧!当然还是应用组件的知识,毕竟趁热打铁
(1)添加组件布局
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref引用</title>
<style type="text/css">
.box{
width: 200px;
height: 200px;
border: 2px solid black;
margin-top: 10px;
}
</style>
</head>
<body>
<div id="app">
<color-template></color-template>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ },
components:{
colorTemplate:{
data(){
return{
colorArray:['red','yellow','green','blue']
}
},
template:`<div class="btn_group">
<button v-for="color in colorArray" :style="{background:color}">{{color}}</button>
<div class="box"></div>
</div>`,
}
}
}) </script>
</body>
</html>
效果
在这里我们定义了局部组件,然后在局部组件中返回了颜色对应的数组,渲染的时候将颜色渲染到对应的按钮上,并且为每个按钮绑定对应的背景颜色。
(2)绑定事件
接下来我们为每一个按钮添加事件,然后点击的时候获取对应的颜色,我们在事件中传入对应的颜色值名称就可以
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref引用</title>
<style type="text/css">
.box{
width: 200px;
height: 200px;
border: 2px solid black;
margin-top: 10px;
}
</style>
</head>
<body>
<div id="app">
<color-template></color-template>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ },
components:{
colorTemplate:{
data(){
return{
colorArray:['red','yellow','green','blue']
}
},
template:`<div class="btn_group">
<button v-for="color in colorArray" :style="{background:color}" @click="handleClick(color)">{{color}}</button>
<div class="box"></div>
</div>`,
methods:{
handleClick(color){
console.log(color);
}
}
}
}
}) </script>
</body>
</html>
结果
当我们依次点击对应的按钮的时候,对应颜色的值已经取到了,当然我们现在已经实现这个功能了,但是为了巩固一下以前的知识,我也会教大家使用另一种方法来获取就是下文提到的dataset的使用。
(3)dataset的使用
在html5中新增了data-xx的属性,我们知道data-xx可以用来存数据所以我们也可以将对应的颜色保存在data-xx中,然后通过dataset获取
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref引用</title>
<style type="text/css">
.box{
width: 200px;
height: 200px;
border: 2px solid black;
margin-top: 10px;
}
</style>
</head>
<body>
<div id="app">
<color-template></color-template>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ },
components:{
colorTemplate:{
data(){
return{
colorArray:['red','yellow','green','blue']
}
},
template:`<div class="btn_group">
<button v-for="color in colorArray" :style="{background:color}" @click="handleClick" :data-color="color">{{color}}</button>
<div class="box"></div>
</div>`,
methods:{
handleClick(e){
const color=e.target.dataset.color;
console.log(color);
}
}
}
}
}) </script>
</body>
</html>
使用这种方法也可以实现依次点击,获取对应颜色的值,结果的话和上面的结果一样,在这里我就不截图了
(4)实现效果
获取到对应的颜色之后我们就要实现如上的效果,现在就必须用到ref的引用了
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref引用</title>
<style type="text/css">
.box{
width: 200px;
height: 200px;
border: 2px solid black;
margin-top: 10px;
}
</style>
</head>
<body>
<div id="app">
<color-template></color-template>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{ },
computed:{ },
components:{
colorTemplate:{
data(){
return{
colorArray:['red','yellow','green','blue']
}
},
template:`<div class="btn_group">
<button v-for="color in colorArray" :style="{background:color}" @click="handleClick(color)" :data-color="color">{{color}}</button>
<div class="box" ref="squareBox"></div>
</div>`,
methods:{
handleClick(color){
const box=this.$refs.squareBox;
box.style.backgroundColor=color;
}
}
}
}
}) </script>
</body>
</html>
效果
效果的话我们已经实现了,但是我们还是不知道什么是ref,别着急,且听我一一道来
我们知道javascript操作dom是非常消耗性能的,因此在vue中提供了ref来获取相应的dom元素获取方法是this.$refs获取的是所有含有ref引用的dom元素,主要分为四种,如下实例。
(1)单独绑定
单独绑定的话,主要就是获取相应的dom元素,就像原生的javascript获取元素一样或者是jQuery中的$获取元素一样,看下实例就知道了,
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref单独绑定</title>
</head>
<body>
<div id="app">
<div ref="square_box" class="box"></div>
<button @click="handleClick">获取元素</button>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{
handleClick(){
var dom=document.getElementsByClassName('box')[0];
console.log(this.$refs.square_box);
console.log(dom);
}
},
computed:{ } }) </script>
</body>
</html>
在这个实例中,我们使用了两种方法来获取dom元素,一种是使用ref来获取,另一种使用原生的javascript来获取,可以看到两种方法都获取到了dom元素
结果:
(2)绑定重复的元素
在javascript中,我们获取相同的节点是通过document.getElementsByClassName('节点名称')或者document.getElementByName('节点名称'),但是jQuery中使用$来获取的,返回的是一个数组,但是ref绑定多个相同的元素之后,后面绑定的会覆盖前面绑定的,这就是ref绑定元素神奇的一方面。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref绑定重复的元素</title>
</head>
<body>
<div id="app">
<div class="box" ref="v_box"></div>
<div class="box" ref="v_box"></div>
<button @click="hanldeClick">获取元素</button>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{
hanldeClick(){
var doms=document.getElementsByClassName('box');
console.log(doms);
console.log(this.$refs.v_box);
}
},
computed:{ } }) </script>
</body>
</html>
在这个示例中,我们同样使用上面的两种方法来获取元素,这样一对比结果就出来了,使用ref获取的元素只用一个,就是最后面写的会覆盖前面写的,总之无论有多个重复的元素使用ref总是会返回最后一个结果。
结果:
(3)v-for中ref实现的效果
如果在实际项目中真的有这个需求,需要绑定多个相同的元素呢?很简单使用v-for就可以了。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>v-for中ref实现的效果</title>
</head>
<body>
<div id="app">
<template v-for="index of 10">
<div class="box" ref="f_box"></div>
</template>
<button @click="handleClick">获取元素</button>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{
handleClick(){
console.log(this.$refs.f_box);
let doms=document.getElementsByClassName('box');
console.log(doms);
}
},
computed:{ } }) </script>
</body>
</html>
同样还是使用两种方法来获取节点,现在的话,我们发现使用ref在v-for循环中获取的dom元素是一个数组(集合),原生的javascript还是没有变和之前的一样
(4)绑定组件
ref强大之处不仅仅表现在前三个方面,它还可以绑定组件呢?绑定组件返回的是组件实例(组件的应用是组件的实例对象),这个也可以说是还有一点用处,这也是ref最后需要介绍的一项。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>ref绑定组件</title>
</head>
<body>
<div id="app">
<hello ref="hello"></hello>
<button @click="handleClick">获取元素</button>
</div>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript">
let vm=new Vue({
el:'#app',
data:{ },
methods:{
handleClick(){
console.log(this.$refs.hello);
}
},
computed:{ },
components:{
'hello':{
'template':'<div>你好</div>',
}
}
})
</script>
</body>
</html>
结果:
可以看到ref绑定组件返回组件实例,ref的使用到这里我就已经讲解完了,总体来说ref还是比较简单的
总结
本篇博客我们主要学习了两个知识点,一个是认识组件(全局组件注册和局部组件注册),第二个是$ref的引用,知识点也比较简单,我讲解的也比较全面,下一篇博客我会带大家详细介绍组件的使用。
vue学习笔记(七)组件的更多相关文章
- vue学习笔记(八)组件校验&通信
前言 在上一章博客的内容中vue学习笔记(七)组件我们初步的认识了组件,并学会了如何定义局部组件和全局组件,上一篇内容仅仅只是对组件一个简单的入门,并没有深入的了解组件当中的其它机制,本篇博客将会带大 ...
- vue 自学笔记(七) 组件细节问题
前情提要: 这里盘点一下,组件细节的问题 现在我们观察一些用框架开发的网页BiliBili.掘金,会发现很多部分都十分相似或者一模一样,我们甚至可以将其拆分归类.而事实上,页面的确是被一个个组件构成的 ...
- Vue 学习笔记之 —— 组件(踩了个坑)
最近在学习vue,学习组件时,遇到了一个问题,困扰了半个多小时.. <!DOCTYPE html> <html lang="en"> <head> ...
- Vue学习笔记七:Vue中的样式
目录 两种样式 class样式 内联样式 两种样式 Vue中使用样式方式有两种,一种是class样式,一种是内联样式也就是style class样式 class样式使用的方式有5种,HTML如下 &l ...
- vue学习笔记(九)vue-cli中的组件通信
前言 在上一篇博客vue学习笔记(八)组件校验&通信中,我们学会了vue中组件的校验和父组件向子组件传递信息以及子组件通知父组件(父子组件通信),上一篇博客也提到那是对组件内容的刚刚开始,而本 ...
- Vue学习笔记-Vue.js-2.X 学习(三)===>组件化高级
(四) 组件化高级 1.插槽(slot)的基本使用 A:基本使用: <slot></slot> B:默认置:<slot><h1>中间可以放默认值< ...
- Vue学习笔记-Vue.js-2.X 学习(二)===>组件化开发
===重点重点开始 ========================== (三) 组件化开发 1.创建组件构造器: Vue.extends() 2.注册组件: Vue.component() 3.使用 ...
- AntDesign vue学习笔记(七)Form 读写与图片上传
AntDesign Form使用布局相比传统Jquery有点繁琐 (一)先读写一个简单的input为例 <a-form :form="form" layout="v ...
- Vue学习笔记-2
前言 本文非vue教程,仅为学习vue过程中的个人理解与笔记,有说的不正确的地方欢迎指正讨论 1.computed计算属性函数中不能使用vm变量 在计算属性的函数中,不能使用Vue构造函数返回的vm变 ...
随机推荐
- 星云测试插装编译流程与CI集成
星云测试Horn插装采用脚本配置方式自动对语法进行扫描和插装,在整个插装过程中需要用到星云提供的插件工具.通过与CI集成,在CI编译前通过jenkins调用星云插装插件模块进行必要的数据填充,生成对应 ...
- vue 开发插件流程
UI demo UI 插件汇总 我的github iSAM2016 在练习写UI组件的,用到全局的插件,网上看了些资料.看到些的挺好的,我也顺便总结一下写插件的流程: 声明插件-> 写插件-&g ...
- vue与element ui的el-checkbox的坑
一,场景 通过使用checkbox,实现如图的场景, 点击某个tag,实现选中和非选中状态. 二, 官网的例子 通过切换checked值为true或者false来实现,一个checkbox的状态切换 ...
- Spring(三)面向切面编程(AOP)
在直系学长曾经的指导下,参考了直系学长的博客(https://www.cnblogs.com/WellHold/p/6655769.html)学习Spring的另一个核心概念--面向切片编程,即AOP ...
- chrome安装json美化软件 JSONView
安装效果如下: 安装步骤: 1.下载地址: github地址:https://github.com/gildas-lormeau/JSONView-for-Chrome 2.解压文件 3.打开谷歌浏览 ...
- Java设计模式_七大原则
简介 单一职责原则.对类来说,即一个类应该只负责一项职责. 开闭原则.对扩展开放,对修改关闭.在程序需要进行扩展的时候,不能去修改原有代码,使用接口和抽象类实现一个热插拔的效果. 里氏替换原则.任何基 ...
- 学习笔记59_python字符串处理
python中,字符串可以使用 '或"括起来 1. 要想写成 "hellow "aaaa" ",在python中,可以"hellow ' ...
- 手写SpringMVC 框架
手写SpringMVC框架 细嗅蔷薇 心有猛虎 背景:Spring 想必大家都听说过,可能现在更多流行的是Spring Boot 和Spring Cloud 框架:但是SpringMVC 作为一款实现 ...
- vue学习之插槽
插槽 插槽(Slot)是Vue提出来的一个概念,正如名字一样,插槽用于决定将所携带的内容,插入到指定的某个位置,从而使模板分块,具有模块化的特质和更大的重用性. 个人理解:我感觉插槽就是父组件控制插槽 ...
- Android 开源库 GitHub 托管
本文微信公众号「AndroidTraveler」首发. 背景 之前给大家写过一篇文章 Android 上传开源项目到 jcenter 实战踩坑之路,分享了上传开源项目到 jcenter 上面的一些踩坑 ...