首页 > 其他分享 >Vue学习记录--定义局部子组件以及组件切换

Vue学习记录--定义局部子组件以及组件切换

时间:2022-11-09 15:02:35浏览次数:49  
标签:Vue -- component 实例 template 组件 login


使用​​components​​属性定义局部子组件

  1. 组件实例定义方式:
<script>
// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {},
methods: {},
components: { // 定义子组件
account: { // account 组件
template: '<div><h1>这是Account组件{{name}}</h1><login></login></div>', // 在这里使用定义的子组件
components: { // 定义子组件的子组件
login: { // login 组件
template: "<h3>这是登录组件</h3>"
}
}
}
}
});
</script>
  1. 引用组件:
<div id="app">
<account></account>
</div>

使用​​flag​​​标识符结合​​v-if​​​和​​v-else​​切换组件

  1. 页面结构:
<div id="app">
<input type="button" value="toggle" @click="flag=!flag">
<my-com1 v-if="flag"></my-com1>
<my-com2 v-else="flag"></my-com2>
</div>
  1. Vue实例定义:
<script>
Vue.component('myCom1', {
template: '<h3>奔波霸</h3>'
})

Vue.component('myCom2', {
template: '<h3>霸波奔</h3>'
})

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
flag: true
},
methods: {}
});
</script>

使用​​:is​​属性来切换不同的子组件,并添加切换动画

  1. 组件实例定义方式:
// 登录组件
const login = Vue.extend({
template: `<div>
<h3>登录组件</h3>
</div>`
});
Vue.component('login', login);

// 注册组件
const register = Vue.extend({
template: `<div>
<h3>注册组件</h3>
</div>`
});
Vue.component('register', register);

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: { comName: 'login' },
methods: {}
});
  1. 使用​​component​​​标签,来引用组件,并通过​​:is​​属性来指定要加载的组件:
<div id="app">
<a href="#" @click.prevent="comName='login'">登录</a>
<a href="#" @click.prevent="comName='register'">注册</a>
<hr>
<transition mode="out-in">
<component :is="comName"></component>
</transition>
</div>

组件切换

<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
</head>

<body>
<div id="app">
<a href="" @click.prevent="comName='login'">登录</a>
<a href="" @click.prevent="comName='register'">注册</a>

<!-- Vue提供了 component ,来展示对应名称的组件 -->
<!-- component 是一个占位符, :is 属性,可以用来指定要展示的组件的名称 -->
<component :is="comName"></component>

<!-- 总结:当前学习了几个 Vue 提供的标签了??? -->
<!-- component, template, transition, transitionGroup -->

</div>

<script>
// 组件名称是 字符串
Vue.component('login', {
template: '<h3>登录组件</h3>'
})

Vue.component('register', {
template: '<h3>注册组件</h3>'
})

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
comName: 'login' // 当前 component 中的 :is 绑定的组件的名称
},
methods: {}
});
</script>
</body>

</html>
  1. 添加切换样式:
<style>
.v-enter,
.v-leave-to {
opacity: 0;
transform: translateX(30px);
}

.v-enter-active,
.v-leave-active {
position: absolute;
transition: all 0.3s ease;
}

h3{
margin: 0;
}
</style>

添加切换动画的组件切换

<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<script src="./lib/vue-2.4.0.js"></script>
<style>
.v-enter,
.v-leave-to {
opacity: 0;
transform: translateX(150px);
}

.v-enter-active,
.v-leave-active {
transition: all 0.5s ease;
}
</style>
</head>

<body>
<div id="app">
<a href="" @click.prevent="comName='login'">登录</a>
<a href="" @click.prevent="comName='register'">注册</a>

<!-- 通过 mode 属性,设置组件切换时候的 模式 -->
<transition mode="out-in">
<component :is="comName"></component>
</transition>

</div>

<script>
// 组件名称是 字符串
Vue.component('login', {
template: '<h3>登录组件</h3>'
})

Vue.component('register', {
template: '<h3>注册组件</h3>'
})

// 创建 Vue 实例,得到 ViewModel
var vm = new Vue({
el: '#app',
data: {
comName: 'login' // 当前 component 中的 :is 绑定的组件的名称
},
methods: {}
});
</script>
</body>

</html>


标签:Vue,--,component,实例,template,组件,login
From: https://blog.51cto.com/u_14020077/5836619

相关文章

  • 高数-微分
    前言以下截图来自bilibili的宋浩老师陈杰老师,我不生产资源,我只是资源的搬运工。宋浩老师的课适合一刷,陈杰老师的适合二刷,最后就是自己刷题复习了,如果大一大二没有认真听......
  • kafka Java客户端之 consumer API 消费消息
    背景:我使用docker-compose搭建的kafka服务​kafka的简单介绍以及docker-compose部署单主机Kafka集群​​使用consumerAPI消费指定Topic里面的消息首先我们需要使用AdminA......
  • 技术分享:IPv6升级转换常见问题盘点
                 随着IPv6网络的普及,IPv6环境的问题处理已经成为网站管理员的必修课,但是由于绝大部分网站运维人员对IPv6网络的接触都不深,因此网站进行IPv6......
  • 小程序promise封装
    小程序promise封装//ajaxpromise封装constrequestFetch=(url,method,param)=>{//一个页面中可能会发送多个请求,ajaxTimes记载同时发送异步请求代码的次数,目......
  • Docker安装Mysql8
    ​​CentOS7.9安装Docker​​拉取mysql镜像搜寻仓库里面有那些镜像dockersearchmysql我们拉取mysql:latest的镜像dockerpullmysql:latest查看镜像但是我们不知道m......
  • 决策 AI:以高效落地为目标的工程技术
    本文整理自第四范式技术日中第四范式技术总裁、基础技术负责人郑曌在主论坛的演讲。大家好,我是郑曌,很荣幸今天能代表第四范式,和大家分享第四范式在决策AI工程技术方向的创......
  • 同步与异步;阻塞与非阻塞
    阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态,是对客户端说的同步和异步是通信机制,是对服务端说的拿餐厅吃饭举例:同步:客人(客户端)去餐厅(服务端)吃饭,点了一杯饮料......
  • js-Date扩展format()函数--处理时间字符串格式
    js-Date扩展format()函数--处理时间字符串格式constformatNumber=n=>{n=n.toString()returnn[1]?n:`0${n}`}处理月份和天的日期字符串,就是个位数前......
  • 防抖与节流
    防抖和节流是针对响应跟不上触发频率这类问题的两种解决方案。在给DOM绑定事件时,有些事件我们是无法控制触发频率的。如鼠标移动事件onmousemove,滚动滚动条事件onscrol......
  • BloodHound学习
    一、LDAP目录服务(1)目录服务是一个特殊的数据库,用来保存描述性的、基于属性的详细信息,支持过滤功能(2)是动态的,灵活的,易扩展的。ex.电话簿、地址簿LDAP......