36. Vue组件切换-使用component元素实现组件切换

需求

在登陆页面的需求中,一般都会有登陆、注册两个按钮,然后点击不同的按钮显示不同的页面。在这里对应的页面可以是一个组件。

那么通过点击不同的按钮,切换不同的组件页面。

下面使用v-ifv-else结合flag来实现这个页面的切换需求。

示例

1.首先创建两个全局组件,作为切换的页面

36. Vue组件切换-使用component元素实现组件切换
image-20200207152410264

2.设置切换按钮,以及应用两个组件

36. Vue组件切换-使用component元素实现组件切换
image-20200207152448744

3.给不同的按钮设置click改变flag的值,通过v-ifv-false结合flag来进行组件切换

36. Vue组件切换-使用component元素实现组件切换
image-20200207152617838

4.查看浏览器显示

36. Vue组件切换-使用component元素实现组件切换
image-20200207152642423
36. Vue组件切换-使用component元素实现组件切换
image-20200207152655264

点击登陆或者注册,切换不同的组件。

那么看到这里,应该就会带来一个疑问,就是v-ifv-else之间是不是就是靠flag作为组合联系的呢。

如果在现在的基础上,在写一个组件3、组件4,用另一个flag2来控制新的切换,是否可以的?

5.编写新的组件3、组件4以及定义flag2参数

36. Vue组件切换-使用component元素实现组件切换
image-20200207153140841

6.给组件3、组件4设置按钮进行切换

36. Vue组件切换-使用component元素实现组件切换
image-20200207153600478

7.确认两台组件之间是否会相互影响

36. Vue组件切换-使用component元素实现组件切换
image-20200207155337221

完整示例代码

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<!-- 导入Vue.js库 -->
<script src="lib/vue.js"></script>

</head>
<body>

<div id="app1">

<a href="" @click.prevent="flag=true">登陆</a>
<a href="" @click.prevent="flag=false">注册</a>

<!-- 登陆组件 -->
<login v-if="flag"></login>

<!-- 注册组件 -->
<register v-else="flag"></register>

<hr>

<a href="" @click.prevent="flag2=true">组件3</a>
<a href="" @click.prevent="flag2=false">组件4</a>

<!-- 组件3 -->
<my-com3 v-if="flag2"></my-com3>

<!-- 组件4 -->
<my-com4 v-else="flag2"></my-com4>

</div>

<script>
// 创建登陆组件
Vue.component('login',{
template:'<h1>登陆组件</h1>'
})

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

// 创建组件3
Vue.component('my-com3',{
template:'<h1>组件3</h1>'
})

// 创建组件4
Vue.component('my-com4',{
template:'<h1>组件4</h1>'
})

// 创建第一个Vue的实例
var vm1 = new Vue({
el: '#app1',
data: {
flag: true,
flag2: true,
},
})

</script>

</body>
</html>

交流QQ群:


36. Vue组件切换-使用component元素实现组件切换


36. Vue组件切换-使用component元素实现组件切换



点击下面,查看更多Vue系列文章

36. Vue组件切换-使用component元素实现组件切换36. Vue组件切换-使用component元素实现组件切换




36. Vue组件切换-使用component元素实现组件切换




原文始发于微信公众号(海洋的渔夫):36. Vue组件切换-使用component元素实现组件切换

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/32426.html

(0)
小半的头像小半

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!