Javascript - Vue - 组件
创建组件
组件是可以重复使用的html容器,可以把它注册到全局的Vue或实例的vue对象上,使它成为全局组件或vue对象的子组件,然后可以将它的html标签插入html文档中。组件的html只能有一个root元素。
使用声明式的方法创建组件
var tt=Vue.extend({
template:"<div>hello vue</div>"
});
Vue.component("tt", tt); //参数1是组件的html标签名,参数2是组件对象名
//方式二
var tt = {
template: "<div>hello vue</div>"
};
Vue.component("tt", tt);
//方式三
var vv = new Vue({
el: ".box",
components: {
tt: {
template: "<div>hello vue</div>"
}
}
});
template指向的html还可以直接写在template标签里,然后通过id或class引入
<div>hello vue</div>
</template>
template:"#template-box"
});
var tt = {
template: "#template-box"
};
var vv = new Vue({
el: ".box",
components: {
tt: {
template: "#template-box"
}
}
});
使用vue文件创建组件
创建一个components目录,在目录下创建一个html,把后缀名改为.vue,清空该文档,然后把template写进去。这种文件就是vue专用的组件文件,在template标签下可以写任何html标签,支持html、script、style标签。
<div>
<h1>{{msg}}</h1>
</div>
</template>
<script>
//此处可以使用ES6语法导入js、css文件
//表示导出这个组件对象
export default {
//组件对象可以看成是一个特殊的vue对象,用法与在vue对象差不多,只是data必须是一个函数,它必须返回一个匿名的对象,而真正的data就放在匿名对象中
data: function () {
return {
msg:"hello vue"
}
}
}
</script>
<style></style>
然后导入这个组件对象,把它注册在vue对象上
import tt from "./components/tt.vue";
var vm = new Vue({
el: ".box",
components: {
tt: tt
}
});
现在可以在vue对象绑定的那个html中使用组件了
<tt></tt>
</div>
*组件的html名字如果是驼峰形式,那么插入html时,必须使用连字符:
template:"<div>hello vue</div>"
}
Vue.component("myCom",tt);
子父组件传值
子组件取父组件的数据、调用父组件的函数 $parent
el: ".box",
data: {
msg:"test"
},
methods: {
getParentFunction: function () {
alert("OK");
}
},
components: {
tt: tt
}
});
<div>
<button @click="getParentData">getParentData</button>
</div>
</template>
<script>
export default {
data: function () {
return {
msg:"hello vue"
}
},
methods: {
getParentData: function () {
alert(this.$parent.msg);
this.$parent.getParentFunction();
}
}
}
</script>
父组件取子组件的数据 $refs
使用vue的$refs对象可以获取为子组件定义的ref引用,通过这种方式获取子组件对象,然后得到子组件的数据或函数。ref只能用在子组件上,对父组件无效。
<div></div>
</template>
<script>
export default {
data: function () {
return {
msg: "hello vue"
}
},
methods: {
getChildFunction: function () {
alert("OK");
}
}
}
</script>
<tt ref="mytt"></tt>
</div>
el: ".box",
methods: {
getChildData: function () {
alert(this.$refs.mytt.msg);
this.$refs.mytt.getChildFunction();
}
},
components: {
tt: tt
}
});
切换子组件
除了html标签:template,vue还提供了component标签,这个html标签用于装载组件,它的html属性:is用于指定装载的组件的名字(组件对象的名字),利用is属性可以实现在html标签component中动态切换组件。
<a href="#" @click="login">login</a>
<a href="#" @click="register">register</a>
<component :is="componentName"></component>
</div>
<script>
Vue.component("login", {
template: "<h3>login区域</h3>"
});
Vue.component("register", {
template: "<h3>register区域</h3>",
});
var vm = new Vue({
el: "#box",
data: {
componentName:null
},
methods: {
login: function () {
this.componentName = "login";
},
register: function () {
this.componentName = "register";
}
}
});

渲染组件
vue提供render来将组件对象渲染到html文档,这样做会使组件直接替换掉绑定到vue上的那个html元素。
template: "<h1>hello world</h1>"
};
var vm = new Vue({
el: "#box",
render: function (create) {
return create(tem);
}
});
组件的生命周期
与vue对象的生命周期是一样的。
在vue组件文件中获取外部文件中的dom元素
通常情况下,一个页面会有N个组件,如果你使用.vue文件创建组件,那么在组件文件中如何访问在同一个页面上的其它组件里的html元素呢?答案是只要这些组件在同一个页面上,那就可以直接使用js原生方法document.querySelector获取其它组件里的html元素。
Javascript - Vue - 组件的更多相关文章
- Javascript - Vue - webpack中的组件、路由和动画
		
引入vue.js 1.cnpm i vue -S 2.在mian.js中引入vue文件 import Vue from "vue"//在main.js中使用这种方式引用vue文件时 ...
 - vue组件
		
分享出来让思路更成熟. 首先组件是 Vue.js 最强大的功能之一. 可以减少很多的工作量,提高工作效率. 编写一个可复用性的组件,虽然官网上也有.... 编写可复用性的vue组件 具备一下的几个要求 ...
 - vue组件最佳实践
		
看了老外的一篇关于组件开发的建议(强烈建议阅读英文原版),感觉不错翻译一下加深理解. 这篇文章制定一个统一的规则来开发你的vue程序,以至于达到一下目的. 1.让开发者和开发团队更容易发现一些事情. ...
 - JS组件系列——又一款MVVM组件:Vue(二:构建自己的Vue组件)
		
前言:转眼距离上篇 JS组件系列——又一款MVVM组件:Vue(一:30分钟搞定前端增删改查) 已有好几个月了,今天打算将它捡起来,发现好久不用,Vue相关技术点都生疏不少.经过这几个月的时间,Vue ...
 - vue组件大集合 component
		
vue组件分为全局组件.局部组件和父子组件,其中局部组件只能在el定义的范围内使用, 全局组件可以在随意地方使用,父子组件之间的传值问题等. Vue.extend 创建一个组件构造器 template ...
 - 【Vue】详解Vue组件系统
		
Vue渲染的两大基础方式 new 一个Vue的实例 这个我们一般会使用在挂载根节点这一初始化操作上: new Vue({ el: '#app' }) 注册组件并使用—— 全局注册 通过Vue.comp ...
 - Vue组件模板形式实现对象数组数据循环为树形结构
		
数据结构为数组中包含对象--树形结构,用Vue组件的写法实现以下的效果: 树形列表,缩进显示层级,第5级数据加底色,数据样式显色,点击展开折叠数据.本文为用Vue实现方式,另有一篇为用knockout ...
 - canvas实现倒计时效果示例(vue组件内编写)
		
前言: 此事例是在vue组件中,使用canvas实现倒计时动画的效果.其实,实现效果的逻辑跟vue没有关系,只要读懂canvas如何实现效果的这部分逻辑就可以了 canvas动画的原理:利用定时器,给 ...
 - Vue (三)    --- Vue 组件开发
		
------------------------------------------------------------------好心情,会让你峰回路转. 5. 组件化开发 5.1 组件[compo ...
 
随机推荐
- 【论文阅读】DSDNet Deep Structured self-Driving Network
			
前言引用 [2] DSDNet Deep Structured self-Driving Network Wenyuan Zeng, Shenlong Wang, Renjie Liao, Yun C ...
 - 论文阅读:LIC-Fusion: LiDAR-Inertial-Camera Odometry
			
本文提出了一种紧耦合的多传感器(雷达-惯导-相机)融合算法,将IMU测量.稀疏视觉特征.提取的激光点融合.提出的算法在时间和空间上对三个异步传感器进行在线校准,补偿校准发生的变化.贡献在于将检测和追踪 ...
 - 基于小熊派Hi3861鸿蒙开发的IoT物联网学习【一】
			
基于小熊派鸿蒙季BearPi-HM_Nano HarmonyOS 鸿蒙系统Hi3861开发板NFC 开发步骤:1.购买开发板:某宝上购买就行 2.安装开发环境 3.下载源码 4.编写案例并执行 开发 ...
 - kali操作系统添加中文输入法
			
今天一通操作真心累啊.想安装搜狗输入法,百度搜索了好多 三步走:https://blog.csdn.net/qq_44110340/article/details/101382732 一顿操作猛如虎, ...
 - react native踩坑记录
			
一 .安装 1.Python2 和Java SE Development Kit (JDK)可以直接通过腾讯电脑关键安装, Android SDK安装的时候路径里不能有中文和空格 2.配置java环境 ...
 - php-socket通信演示
			
client: error_reporting(E_ALL); set_time_limit(0); echo "<h2>TCP/IP Connection</h2> ...
 - Spring Data Commons 远程命令执行漏洞(CVE-2018-1273)
			
影响版本 Spring Framework 5.0 to 5.0.4 Spring Framework 4.3 to 4.3.14 poc https://github.com/zhzyker/exp ...
 - 字符串对象 API
			
length--获取字符串的长度 charAt(n)--查找下标对应的字符串 indexOf(str)--查找某个字符首次出现的下标,找不到返回-1 lastIndexOf(str)--查找某个字符最 ...
 - 自学linux——17.selinux的了解及使用
			
SElinux是强制访问控制(MAC)安全系统,是linux历史上最杰出的新安全系统.对于linux安全模块来说,SElinux的功能是最全面的,测试也是最充分的,这是一种基于内核的安全系统. 1.S ...
 - Windows系统安装Mariadb数据库(zip包方式安装)--九五小庞
			
1.去Mariadb官网下载zip安装包 下载地址:https://downloads.mariadb.org/mariadb/10.3.31/ 2.解压压缩包到指定的安装位置 3.在安装包的data ...