2021-06-10

踩坑

最开始想的是通过将当前:default-active="activeIndex"的值保存在localStorage中来实现刷新后导航栏高亮的问题,点击刷新是ok了,结果却有一个更大的坑,从地址栏改变页面,发现高亮的还是之前的导航,嗯。。。想哭ing,最后想着应该从地址跳转来匹配设置高亮,最后查了网上的一些文章,实现之后,记录下这个笔记。

参考资料https://blog.csdn.net/m0_38134431/article/details/94755527

实现核心

通过路由router设置路由元信息(meta)记录地址,在MenuNav中读取meta中设置的信息,匹配el-menu-item中index的值,来解决刷新或地址改变造成的一些导航栏高亮问题

实现步骤

在router下index.js meta中设置一个activeMenu来记录地址(数字也行,最好是地址,比较清楚)。

 {
        path: 'params',
        name: 'Params',
        component: Params,
        meta:{
          isLogin:true,
          activeMenu:'params'
        }
 },

在NamMenu.vue中设置el-menu-item中的index=“params”(index的值与路由meta中activeMenu一致)

<el-menu-item index="params">
    <router-link class="router-text" to="/params">
        <i class="el-icon-copy-document"></i>
        <span class="top-text">规格参数</span>
    </router-link>
</el-menu-item>

在computed中获取meta中activeMenu的值,并与el-menu-item中index值匹配,从而实现根据地址高亮

// 我们使用计算属性来获取到当前点击的菜单的路由路径,然后设置default-active中的值
// 使得菜单在载入时就能对应高亮
 activeMenu() {//el-menu中:default-active="activeMenu"
     const route = this.$route
     console.log(route);
     const { meta, path } = route
     // if set path, the sidebar will highlight the path you set
     // 可以在路由配置文件中设置自定义的路由路径到meta.activeMenu属性中,来控制菜单自定义高亮显示
     if (meta.activeMenu) {
         return meta.activeMenu
     }
     return path
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,我们可以使用SimpleDateFormat类来将时间字符串转换为年月日格式。首先,你需要创建一个SimpleDateFormat的对象,并指定日期格式,例如"yyyy-MM-dd"表示年月日的格式。然后,使用该对象的parse()方法将时间字符串解析为一个Date对象。最后,再次使用SimpleDateFormat对象的format()方法将Date对象格式化为另一种日期格式,例如"yyyy年MM月dd日"表示年月日的格式。 以下是一个示例代码: ```java import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; public class DateConversion { public static void main(String[] args) { String dateString = "2021-06-10"; SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); try { Date date = dateFormat.parse(dateString); SimpleDateFormat outputFormat = new SimpleDateFormat("yyyy年MM月dd日"); String formattedDate = outputFormat.format(date); System.out.println(formattedDate); } catch (ParseException e) { e.printStackTrace(); } } } ``` 在上面的代码中,我们首先创建了一个SimpleDateFormat对象dateFormat,用于解析时间字符串"2021-06-10"。然后使用parse()方法将时间字符串解析为一个Date对象date。接下来,我们再次创建了一个SimpleDateFormat对象outputFormat,用于定义输出的日期格式为"yyyy年MM月dd日"。最后,使用format()方法将Date对象date格式化为所需的日期格式,并将结果打印出来。 运行以上代码,将输出"20210610日"。这样,我们就成功地将时间字符串转换为年月日格式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值