为了账号安全,请及时绑定邮箱和手机立即绑定

Vue.js中多个兄弟组件中如何共用一个公共的组件?

Vue.js中多个兄弟组件中如何共用一个公共的组件?

红颜莎娜 2018-07-11 20:14:55
 【问题】:请问下多个兄弟组件中如何共用一个公共的组件?【描述】:进入我的网站,根据路由不同,对应不同的组件(后面统称组件1),在这些组件中,又有公共的部分(后面统称组件2),但是在公共部分中,里面的某些数据,我需要根据组件1中传不同的数据,这个要怎么实现?【效果】:比如在上面图1的这个顶部,这个标题和按钮中的text,我都希望根据组件1来传递。【业务】:用户首页点击图2中的用户信息,跳转进入图2(用户详情界面),其他有些模块类似。【代码】:... { //图2 router     path: '/user',      name: 'User',      meta: { ... },      components: {          default: User,          footer: Footer      }  }, {  //图1 router     path: '/user/detail',      name: 'UserDetail',      meta: { ... },      component: UserDetail         //components: {          //default: UserDetail,          //header: Header  //图2中顶部公共组件      //} } ...个人想用vue-router中的children来实现,但是发现好像不能这么做刚入坑不久,请问下大神们要怎么实现?给个思路就可以了,问题有点小白,不喜勿喷,谢谢!
查看完整描述

3 回答

?
一只甜甜圈

TA贡献1836条经验 获得超5个赞

我知道一个方法是在index.js中用

Vue.component('header-item', {
  props: ['message', 'backUrl'],
  template: `...`
})

在其他页面中用

<header-item message="我是demo1头部" backUrl="/"></header-item>

但是有没有其他的方法?一般在公司实战项目中采用的方法是什么?

方法二:
1、定义一个单独的header.vue公共组件
代码如下:(采用了iView)

<template>
    <Layout>
        <Header>
            {{title}}
        </Header>
    </Layout></template><script>
    export default{        
        props: ['title'],
        data () {            
            return { }
        }
    }</script>

2、在vue-router/index.js中根据需要引入。代码如下:

import Header from '**/Header'...{
  path: '/user/detail',
  name: 'Detail',
  meta: {...},
  components: {
    default: Detail,    
    header: Header
  },
  props: {    
      header: {
      title: '用户信息'
    }
  }
},...

3、页面中引用。代码如下:

<router-view name="header"></router-view>


查看完整回答
反对 回复 2018-07-15
?
慕容3067478

TA贡献1773条经验 获得超3个赞

将你想要复用的部分单独封装在一个vue文件里面,通过props或者vuex来进行state控制。
组件化开发是现在前端非常重要的思想,建议学习。

查看完整回答
反对 回复 2018-07-15
?
千万里不及你

TA贡献1784条经验 获得超9个赞

建议你单独定义一个vue组件
通过父子组件传值控制显示内容
在需要的页面导入组件就好
上面的方法可以,但是局限性太大

查看完整回答
反对 回复 2018-07-15
  • 3 回答
  • 0 关注
  • 2667 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信