Vue-cli项目与element导航菜单控件的结合使用以及遇到的问题
1、基本使用
- 第一种常用写法:导航菜单与 router-view 的配合使用
- 将所用的导航菜单数据编写成一个数组的形式,提高维护性;
- 在utils工具文件夹中建立utils.js文件;
import merge from 'webpack-merge'
/**
* 工具类Class
*/
class testUtils {
constructor() { }
//当前默认语言
static currentLang = 'zh-CN'
//支持国际化语言
static supportLangs = ['zh-CN', 'en-US'] /**
* [mergeI18nFiles 根据url里的language获取国际化文件]
* @param {[JSON]} i18nParams [i18n参数]
* @return {[JSON]} [国际化配置]
*/
mergeI18nFiles(i18nParams) {
return require('@/pages/' + i18nParams.module + '/config/lang/' + i18nParams.lang + '/index')
}
/**
* [getLanguageFromUrl 通过url里的language匹配当支持国际化的language,如果匹配到,返回匹配的language,匹配不到,返回默认language]
* @return {[String]} [匹配的language]
*/
getLanguageFromUrl() {
for (let val of adrsUtils.supportLangs) {
let url = window.location.href
let hashBackUrl = url.substring(url.indexOf('#/') + )
const urlLang = hashBackUrl.substring(, hashBackUrl.indexOf('/'))
if (adrsUtils.supportLangs.includes(urlLang)) {
return urlLang
} else {
return adrsUtils.currentLang
}
}
}
} export default new testUtils()
export { testUtils } - 在app.js文件中引入国际化:
import Vue from 'vue'
import VueI18n from 'vue-i18n'
import testUtils from '@/utils/utils'
Vue.use(VueI18n) //获取url中的language
const language = testUtils.getLanguageFromUrl()
//根据url里的language动态加载language配置文件
let i18nParams = { module: 'index', lang: language }
const messages = testUtils.mergeI18nFiles(i18nParams).default
const i18n = new VueI18n({
locale: language,
messages
}) - 在global文件夹中,建立locale.js文件;
import testUtils from '@/utils/utils'
export default {
install(Vue) {
const language = testUtils.getLanguageFromUrl()
Vue.$language = language
Vue.prototype.$language = language
}
} - 在JS文件夹下面建立data.js文件;
import Vue from 'vue'
const language = Vue.$language
const testingLocale = require(`../../config/lang/${language}/testing_${language}`).default //导航数据 title为导航的内容 iconName是导航图标
export const menuData = [
{
title: testingLocale[language].message.testing.test1,
iconName: require('../../assets/images/test1.png'),
route: {
path: 'test1',
},
},
{
title: testingLocale[language].message.testing.test2,
iconName: require('../../assets/images/test2.png'),
route: {
path: 'test2',
},
}
}
- 在utils工具文件夹中建立utils.js文件;
- 在导航菜单中进行循环;
<el-menu
:default-active="defaultActive"
router
class="el-menu-vertical-demo"
@select="selectRouter"
>
<el-menu-item
:index="value.route.path"
v-for="(value, index) in menuData"
:key="index"
>
<img :src="value.iconName" style="width:28px;height:25px;margin:0 0.5rem" />
<span slot="title">{{value.title}}</span>
</el-menu-item>
</el-menu> - 在data属性中设置默认的打开菜单;
defaultActive: "test1", //默认开启导航
- 在点击菜单的时候,如果存在跳转的条件,可以添加select事件
/**
* [selectRouter 菜单栏选择时的回调 否则可能无法跳转过去]
* params index 选中的菜单路径 是一个字符串
* params indexPath 选中的菜单路径 是一个数组
* @return {[type]} [description]
*/
selectRouter(index, indexPath) {
//未对路由跳转的提交进行限制
router.beforeEach((to, from, next) => { });
},
- 将所用的导航菜单数据编写成一个数组的形式,提高维护性;
- 第二种:导航菜单与子组件的配合使用
- 同样将数据提取出来,设置数组的形式
export const menuData =
[
{ //导航
index: 'register',
name: "导航一",
children: [{ index: 'register', name: '选项一' }],
imgsrc: require('@/pages/index/assets/images/home/register.png')
}, {
index: 'mediationCase',
name: "导航二",
imgsrc: require('@/pages/index/assets/images/home/auditing.png'),
children: []
}
] - 在vue中进行循环
<el-menu
class="el-menu-vertical-demo"
router
:default-active="activeIndex"
unique-opened
text-color="#fff"
>
<div v-for="item in menuData" :key="item.index">
<el-menu-item
:index=" '/' + $route.params.language + '/home/' + item.index"
v-if="item.children.length == 0"
>
<img :src="item.imgsrc" width="18px" />
<span slot="title" style="padding-left: 0.5rem;">{{item.name}}</span>
</el-menu-item>
<el-submenu :index="item.index" v-if="item.children.length > 0">
<template slot="title">
<img :src="item.imgsrc" width="18px" />
<span style="padding-left: 0.5rem;">{{item.name}}</span>
</template>
<el-menu-item-group>
<div v-for="i in item.children" :key="i.index">
<el-menu-item
:index=" '/' + $route.params.language + '/home/' + i.index"
>{{i.name}}</el-menu-item>
</div>
</el-menu-item-group>
</el-submenu>
</div>
</el-menu> - 不采用router-view,而采用子组件进行匹配
<test v-show="defaultActive == 'test'"></test>
- 同样将数据提取出来,设置数组的形式
2、遇到的问题
- 在使用elementUI构建vue项目的时候会遇到,页面刷新的时候路径为刷新之前的子路由,内容也为刷新之前的子路由内容,但是导航栏的高亮却显示在data属性中设置的默认导航栏上;
- 解决方法:在mounted钩子函数中,添加以下代码
this.defaultActive = window.location.hash.split("/")[];
这样在渲染之前先把当前的路由设置给导航栏的默认的路由,则刷新也是显示的当前路由的内容,并且导航栏高亮的也是当前路由的那个选项了
- 解决方法:在mounted钩子函数中,添加以下代码
- 在使用Element UI 时点击同一个路由,控制台报错,错误信息如下
- 解决方法:
经过多次尝试发现原因可能是在重新下载依赖包时,安装的vue-router还是之前出错的那个版本,解决方法也很简单,在项目目录下运行 npm i vue-router@3.0 -S 即可;
- 在引用vue-router的文件中添加以下代码
// 解决在使用Element UI 时点击同一个路由,控制台报错的问题
const originalPush = Router.prototype.push;
Router.prototype.push = function push(location) {
return originalPush.call(this, location).catch(err => err);
};
- 解决方法:
Vue-cli项目与element导航菜单控件的结合使用以及遇到的问题的更多相关文章
- vue+ElementUI项目中,上传控件为必填项,上传图片后清空提示信息
(ps:以下是我在项目中遇到得问题及解决方法,希望对你们有帮助.如果还有其他方法,可以留言,谢谢) 一个表单页面,使用element-ui中el-upload上传图片,此项为必填项,然后写了校验规则, ...
- ASP.NET的面包屑导航控件、树形导航控件、菜单控件
原文:http://blog.csdn.net/pan_junbiao/article/details/8579293 ASP.NET的面包屑导航控件.树形导航控件.菜单控件. 1. 面包屑导航控件— ...
- 改造@vue/cli项目为服务端渲染-ServerSideRender
VUE SEO方案二 - SSR服务端渲染 在上一章中,我们分享了预渲染的方案来解决SEO问题,个人还是很中意此方案的,既简单又能解决大部分问题.但是也有着一定的缺陷,所以我们继续来看下一个方案--服 ...
- 实用的树形菜单控件tree
jQuery plugin: Treeview 这个插件能够把无序列表转换成可展开与收缩的Tree. jQuery plugin: Treeview jQuery jstree jsTree ...
- html树形菜单控件
html树形菜单控件 链接 http://www.ithao123.cn/content-713974.html jQuery plugin: Treeview 这个插件能够把无序 ...
- Redrain 通用菜单控件使用方法和说明(附源码和demo)
转载请说明原出处,谢谢~~:http://blog.csdn.net/zhuhongshu/article/details/42889709 大概半年前我写过博客说明怎么改造duilib的原代Menu ...
- 【转】html树形菜单控件
Query plugin: Treeview 这个插件能够把无序列表转换成可展开与收缩的Tree. 主页:http://bassistance.de/jQuery-plugins/jquery-pl ...
- C#之菜单控件、主窗体打开子窗体、GroupBox控件使用
一.背景 一年前有学习过C#,但没有在项目中去实际做APP,重新捡起来应用到项目中.我同事本来做好一个CANOPEN设备管理的界面,由于近期搜索了别人的开发的界面,我觉得有很多东西要重新安排,以及我已 ...
- Asp.net 菜单控件
本文介绍的菜单控件采用的css 和ul list来显示菜单,生成的html小,无需javascript支持,对大部分的浏览器都支持,除ie6要单独修改css也可以使其支持. 通过本文可以了解asp.n ...
随机推荐
- @PostContruct 连接数据库的问题
在@PostContruct中连接数据库取数据会报错,因为spring的lazy loading机制,不一定所有的bean都已经实例化好了.可以使用ApplicationListener,通过Cont ...
- python基础练习题08
写一个登录程序,让用户输入账号和密码,输入用户和密码输入正确的话,提示你 xxx,欢迎登录,今天的日期是xxx,程序结束.错误的话,提示账号/密码输入错误, 最多输入3次,如果输入3次都没有登录成功, ...
- 微信小程序-自制弹出框禁止页面上下滑动
弹出 fixed 弹窗后,在弹窗上滑动会导致下层的页面一起跟着滚动. 解决方法: 在弹出层加上 catchtouchmove 事件 两种方法:(在电脑上测试是没有用的,这是触摸事件.因此,需要在手机端 ...
- MySQL——Alias
查询时,当表名很长或者执行一些特殊查询的时候,为了方便操作或者需要多次使用相同的表时,可以为表指定别名,用这个别名代替表原来的名称. 设置别名为表设置别名 <表名> [AS] <别名 ...
- 操作系统——HugePage
TLB:页表一般都很大,并且存放在内存中,所以处理器引入MMU后,读取指令.数据需要访问两次内存:首先通过查询页表得到物理地址,然后访问该物理地址读取指令.数据.为了减少因为MMU导致的处理器性能下降 ...
- postman—创建collection,执行collection和批量执行
接口测试中,可以在 Postman 逐个创建请求.但当请求逐渐增多时,如果我们不采取任何措施管理,散乱的请求维护起来就比较麻烦了.这个时候我们可以创建测试集 Collection 来对这些请求进行管理 ...
- 执行jar包某类命令
#!/bin/bash ulimit -SHn 65535 export LC_ALL=en_US.UTF-8 export LANG=en_US.UTF-8 library_path="$ ...
- 关于:基于http协议大文件断点续传上传至web服务器
关键部分 前端用file.slice()分块 前端用FileReader获取每一分块的md5值 后端用MultipartFile接受分块文件 后端用FileOutputStream拼装分块文件 话不多 ...
- 【canvas学习笔记八】像素操作
ImageData对象 ImageData对象包含了一个区域内的canvas的像素信息.它包含以下可读属性: width canvas的宽度,单位是像素. height canvas的高度,单位是像素 ...
- 在ThinkPHP框架(5.0.24)下引入Ueditor并实现向七牛云对象存储上传图片同时将图片信息保存到MySQL数据库,同时实现lazyload懒加载
这是我花了很多天的时间才得以真正实现的一组需求. 文章后面有完整Demo的GitHub链接. 一. 需求描述 1. 应用是基于ThinkPHP5开发的: 2. 服务器环境是LNMP,PHP版本是7.2 ...