Vuejs——(12)组件——动态组件
版权声明:出处http://blog.csdn.net/qq20004604
本篇资料来于官方文档:
http://cn.vuejs.org/guide/components.html#u52A8_u6001_u7EC4_u4EF6
本文是在官方文档的基础上,更加细致的说明,代码更多更全。
简单来说,更适合新手阅读
(二十九)组件——动态组件
①简单来说:
就是几个组件放在一个挂载点下,然后根据父组件的某个变量来决定显示哪个,或者都不显示。
②动态切换:
在挂载点使用component标签,然后使用v-bind:is=”组件名”,会自动去找匹配的组件名,如果没有,则不显示;
改变挂载的组件,只需要修改is指令的值即可。
如示例代码:
- <div id="app">
- <button @click="toshow">点击让子组件显示</button>
- <component v-bind:is="which_to_show"></component>
- </div>
- <script>
- var vm = new Vue({
- el: '#app',
- data: {
- which_to_show: "first"
- },
- methods: {
- toshow: function () { //切换组件显示
- var arr = ["first", "second", "third", ""];
- var index = arr.indexOf(this.which_to_show);
- if (index < 3) {
- this.which_to_show = arr[index + 1];
- } else {
- this.which_to_show = arr[0];
- }
- }
- },
- components: {
- first: { //第一个子组件
- template: "<div>这里是子组件1</div>"
- },
- second: { //第二个子组件
- template: "<div>这里是子组件2</div>"
- },
- third: { //第三个子组件
- template: "<div>这里是子组件3</div>"
- },
- }
- });
- </script>
说明:
点击父组件的按钮,会自动切换显示某一个子组件(根据which_to_show这个变量的值来决定)。
③keep-alive
简单来说,被切换掉(非当前显示)的组件,是直接被移除了。
在父组件中查看this.$children属性,可以发现,当子组件存在时,该属性的length为1,而子组件不存在时,该属性的length是0(无法获取到子组件);
假如需要子组件在切换后,依然需要他保留在内存中,避免下次出现的时候重新渲染。那么就应该在component标签中添加keep-alive属性。
如代码:
- <div id="app">
- <button @click="toshow">点击让子组件显示</button>
- <component v-bind:is="which_to_show" keep-alive></component>
- </div>
- <script>
- var vm = new Vue({
- el: '#app',
- data: {
- which_to_show: "first"
- },
- methods: {
- toshow: function () { //切换组件显示
- var arr = ["first", "second", "third", ""];
- var index = arr.indexOf(this.which_to_show);
- if (index < 3) {
- this.which_to_show = arr[index + 1];
- } else {
- this.which_to_show = arr[0];
- }
- console.log(this.$children);
- }
- },
- components: {
- first: { //第一个子组件
- template: "<div>这里是子组件1</div>"
- },
- second: { //第二个子组件
- template: "<div>这里是子组件2</div>"
- },
- third: { //第三个子组件
- template: "<div>这里是子组件3</div>"
- },
- }
- });
- </script>
说明:
初始情况下,vm.$children属性中只有一个元素(first组件),
点击按钮切换后,vm.$children属性中有两个元素,
再次切换后,则有三个元素(三个子组件都保留在内存中)。
之后无论如何切换,将一直保持有三个元素。
④activate钩子
简单来说,他是延迟加载。
例如,在发起ajax请求时,会需要等待一些时间,假如我们需要在ajax请求完成后,再进行加载,那么就需要用到activate钩子了。
具体用法来说,activate是和template、data等属性平级的一个属性,形式是一个函数,函数里默认有一个参数,而这个参数是一个函数,执行这个函数时,才会切换组件。
为了证明他的延迟加载性,在服务器端我设置当发起某个ajax请求时,会延迟2秒才返回内容,因此,第一次切换组件2时,需要等待2秒才会成功切换:
- <div id="app">
- <button @click="toshow">点击让子组件显示</button>
- <component v-bind:is="which_to_show"></component>
- </div>
- <script>
- var vm = new Vue({
- el: '#app',
- data: {
- which_to_show: "first"
- },
- methods: {
- toshow: function () { //切换组件显示
- var arr = ["first", "second", "third", ""];
- var index = arr.indexOf(this.which_to_show);
- if (index < 3) {
- this.which_to_show = arr[index + 1];
- } else {
- this.which_to_show = arr[0];
- }
- console.log(this.$children);
- }
- },
- components: {
- first: { //第一个子组件
- template: "<div>这里是子组件1</div>"
- },
- second: { //第二个子组件
- template: "<div>这里是子组件2,这里是ajax后的内容:{{hello}}</div>",
- data: function () {
- return {
- hello: ""
- }
- },
- activate: function (done) { //执行这个参数时,才会切换组件
- var self = this;
- $.get("/test", function (data) { //这个ajax我手动在服务器端设置延迟为2000ms,因此需要等待2秒后才会切换
- self.hello = data;
- done(); //ajax执行成功,切换组件
- })
- }
- },
- third: { //第三个子组件
- template: "<div>这里是子组件3</div>"
- }
- }
- });
- </script>
代码效果:
【1】第一次切换到组件2时,需要等待2秒后才能显示(因为发起ajax);
【2】在有keep-alive的情况下,第二次或之后切换到组件2时,无需等待;但ajax内容,需要在第一次发起ajax两秒后才会显示;
【3】在无keep-alive的情况下(切换掉后没有保存在内存中),第二次切换到组件2时,依然需要等待。
【4】等待时,不影响再次切换(即等待组件2的时候,再次点击切换,可以直接切换到组件3);
说明:
【1】只有在第一次渲染组件时,才会执行activate,且该函数只会执行一次(在第一次组件出现的时候延迟组件出现)
【2】没有keep-alive时,每次切换组件出现都是重新渲染(因为之前隐藏时执行了destroy过程),因此会执行activate方法。
⑤transition-mode过渡模式
简单来说,动态组件切换时,让其出现动画效果。(还记不记得在过渡那一节的说明,过渡适用于动态组件)
默认是进入和退出一起完成;(可能造成进入的内容出现在退出内容的下方,这个下方指y轴方面偏下的,等退出完毕后,进入的才会出现在正确的位置);
transition-mode=”out-in”时,动画是先出后进;
transition-mode=”in-out”时,动画是先进后出(同默认情况容易出现的问题);
示例代码:(使用自定义过渡名和animate.css文件)
- <div id="app">
- <button @click="toshow">点击让子组件显示</button>
- <component v-bind:is="which_to_show" class="animated" transition="bounce" transition-mode="out-in"></component>
- </div>
- <script>
- Vue.transition("bounce", {
- enterClass: 'bounceInLeft',
- leaveClass: 'bounceOutRight'
- })
- var vm = new Vue({
- el: '#app',
- data: {
- which_to_show: "first"
- },
- methods: {
- toshow: function () { //切换组件显示
- var arr = ["first", "second", "third", ""];
- var index = arr.indexOf(this.which_to_show);
- if (index < 3) {
- this.which_to_show = arr[index + 1];
- } else {
- this.which_to_show = arr[0];
- }
- }
- },
- components: {
- first: { //第一个子组件
- template: "<div>这里是子组件1</div>"
- },
- second: { //第二个子组件
- template: "<div>这里是子组件2,这里是ajax后的内容:{{hello}}</div>",
- data: function () {
- return {
- hello: ""
- }
- }
- },
- third: { //第三个子组件
- template: "<div>这里是子组件3</div>"
- }
- }
- });
- </script>
Vuejs——(12)组件——动态组件的更多相关文章
- vue组件---动态组件&异步组件
(1)在动态组件上使用keep-alive 之前曾经在一个多标签的界面中使用 is 特性来切换不同的组件.接下来简单回顾下 <component>元素是vue 里面的一个内置组件.在里面使 ...
- vue深入了解组件——动态组件&异步组件
一.在动态组件上使用 keep-alive 我们之前曾经在一个多标签的界面中使用 is 特性来切换不同的组件: <component v-bind:is="currentTabComp ...
- Vue组件-动态组件
动态组件 通过使用保留的 <component> 元素,动态地绑定到它的 is 特性,可以让多个组件使用同一个挂载点,并动态切换: <div id="app6"& ...
- vue组件---动态组件之多标签页面
首先看下效果图 代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> & ...
- 深入了解组件- -- 动态组件 & 异步组件
gitHub地址:https://github.com/huangpna/vue_learn/example里面的lesson11 一 在动态组件上使用keep-alive 在这之前我们已经有学习过用 ...
- vue-learning:34 - component - 内置组件 - 动态组件component 和 is属性
component动态组件 / is属性 让多个组件使用同一个挂载点,并动态切换,这就是动态组件. 必要条件: 组件标签使用<component></component> 动态 ...
- Vue 组件&组件之间的通信 之 template模板引用与动态组件的使用
template模板引用 在component的template中书写大量的HTML元素很麻烦. Vue提供了<template>标签,可以在里边书写HTML,然后通过ID指定到组建内的t ...
- vue教程3-03 vue组件,定义全局、局部组件,配合模板,动态组件
vue教程3-03 vue组件,定义全局.局部组件,配合模板,动态组件 一.定义一个组件 定义一个组件: 1. 全局组件 var Aaa=Vue.extend({ template:'<h3&g ...
- vuejs动态组件给子组件传递数据
vuejs动态组件给子组件传递数据 通过子组件定义时候的props可以支持父组件给子组件传递数据,这些定义的props在子组件的标签中使用绑定属性即可,但是如果使用的是<component> ...
随机推荐
- 史上最全 40 道 Dubbo 面试题及答案,看完碾压面试官
想往高处走,怎么能不懂 Dubbo? Dubbo是国内最出名的分布式服务框架,也是 Java 程序员必备的必会的框架之一.Dubbo 更是中高级面试过程中经常会问的技术,无论你是否用过,你都必须熟悉. ...
- Spring4新特性
参考 : https://jinnianshilongnian.iteye.com/blog/1990081
- leetcode102
本题是广度优先遍历(BFS)实现树的层次遍历,使用队列实现. class Solution { public: vector<vector<int>> levelOrder(T ...
- C# String 与 StringBuilder
String 字符串不可变性,每次为字符串进行增删或重写赋值会销毁原来的字符串,重新开辟内存空间,因此是非常消耗资源的 字符串可以看做是 char 数组,因此可以用 foreach 对其进行遍历,或者 ...
- ElasicSearch(1)
ElasticSearch是一个基于Lucene的搜索服务器.它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口.Elasticsearch是用Java开发的,并作为Apach ...
- MySQL中的重做日志(redo log),回滚日志(undo log),以及二进制日志(binlog)的简单总结
MySQL中有六种日志文件,分别是:重做日志(redo log).回滚日志(undo log).二进制日志(binlog).错误日志(errorlog).慢查询日志(slow query log).一 ...
- oracle数据库名称已被一现有约束条件占用
使用oracle数据库出现名称已被一现有约束条件占用的错误,我的原因是在同一个库中有一个表使用了外键FK_SNO,自己新建的一个表中也使用了外键FK_SNO,导致出现了错误. 这时改变一下外键FK_S ...
- java学习笔记(五):公共类
什么是公共类,公共类就是和源文件名同名的类,举例来说:类的名称是 public class aaa{},那么源文件就应该是 aaa.java. 每个源文件中只能有一个公共类. 每个源文件可以有很多非公 ...
- [Java核心技术]第四章-对象与类(4.1-4.6总结)
4.1面向对象程序设计概述 OOP(面向对象编程Object Oriented Programming) OOP中数据第一位,算法第二位. 类 封装:关键在于不能让其他方法直接访问类的实例域,程序仅通 ...
- Socket 多线程编程
前面一片学习了TCP/IP的基础网络编程,并给出了简单的服务端与客户端通信交互的例子.还介绍了UPC的通信例子. 这次学习TCP/IP的多线程编程.因为涉及到TCP/IP一般都是多线程,服务端会一直监 ...