vue + router + vant + navbar组件封装

本项目选择vuecli3+vant进行移动端页面开发。
本文是针对导航栏进行的简单封装

1、在main.js中导入NavBar

import { NavBar } from 'vant';
Vue.use(NavBar);

2、创建NavBar组件用来封装vant提供的<van-nav-bar>

2.1设置数据绑定的title,左侧返回箭头是否显示
<template>
  <div id="NavBar">
    <van-nav-bar :title="title" :left-arrow="isleftarrow" @click-left="onClickLeft" />
  </div>
</template>
2.2 使用props由父组件给子组件传值,父组件动态给导航栏赋值。
<script>
export default {
  // title:用来显示导航栏的title,isleftarrow用来显示导航栏的左侧返回箭头
  props: ["title","isleftarrow"],
  methods: {
    onClickLeft() {
      // 点击回退的时候当做地址回退
      this.$router.go(-1);
    }
  }
};
</script>
<style scoped>
#NavBar {
  position: fixed;
  top: 0;
  left: 0;
  height: 46px;
  line-height: 46px;
  width:100%;
  z-index: 100;
}
.van-nav-bar{
  font-size: 18px!important;
  /* 设置导航栏的渐变色 */
  background: linear-gradient(to right, #ff2e29, #fe6e49)!important;
  background: -webkit-linear-gradient(to right, #ff2e29, #fe6e49)!important;
  border:0;
}
.van-hairline--bottom::after {
     /* 去除导航栏底部的白色横线 */
    border-bottom-width: 0px!important;
}

</style>

3、在父组件中使用该导航栏作为公共部分并赋值

  <div id="app">
    <NavBar v-show="navShow" :title="title" :isleftarrow="isleftarrow">      </NavBar>
3.1引用导航栏组件
import NavBar from "./components/Common/NavBar.vue";
export default {
  components: {
    NavBar
  },
3.2设置属性值与导航栏组件进行数据绑定(title:'', isleftarrow:'')
  data() {
    return {
      title:'',
      isleftarrow:'',
      transitionName: "fade",
      navShow: true
    };
  },
3.3在mounted中给 title和isleftarrow赋值

:在模板渲染成html后调用,通常是初始化页面完成后,再对html的dom节点进行一些需要的操作。

  mounted() {
    this.title = this.$route.meta.title;
    this.isleftarrow = this.$route.meta.isleftarrow;       
  },
3.4使用watch检测路由切换给 title和isleftarrow赋值。
  watch: {
    $route(to, from) {
      this.title = to.meta.title;
      this.isleftarrow =  to.meta.isleftarrow;
     }
  }

4、在router.js中设置meta(在3.3和3.4的取值使用)

routes: [
{
  path: '/apply',
  name: 'apply',
  meta: { title: '导航标题1', isleftarrow:true  },
  component: Apply
},
{
  path: '/',
  name: 'exhibition',
  meta: { title: '导航标题2', isleftarrow:false },
  component: Exhibition
}
]
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 下午妈妈下班去辅导班接你回家,一直吃饭挑挑拣拣的你居然自己说吃了一半的馒头,这可能对于其他小朋友来说很简单的事...
    嘉祺妈妈阅读 211评论 0 1
  • 文衙弄5号,听到这样的地址,是不是会联想到深巷厚墙攀缘着古藤的模样?艺圃这个低调的藏在深巷里的世界文化遗产让你想起...
    西州路西阅读 1,818评论 2 3
  • 13. 我醒了 唤醒我的不是春天 是我对爱的希望 14. 我小心翼翼地活着每天 生怕一不小心便遇不着你 15. 想...
    年轻的风阅读 228评论 3 1
  • 在作业辅导结束时,我会专门安排一个时间供学生提问。问的内容是白天上课没有听懂的或做练习时不会的,只要是不明白的都可...
    及第教育阅读 98评论 0 0