博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
导航点击选中效果重构
阅读量:6858 次
发布时间:2019-06-26

本文共 1272 字,大约阅读时间需要 4 分钟。

一、场景

最近做重构,有一个功能是,鼠标点击链接后显示不同样式:

代码如下,样式布局我修改后如下,使用bootstrap框架来做。

    
starof test

现在重点说一下:功能实现。

原来代码是这样实现链接点击样式的,给每个链接不同的class,

然后在page1.html页面定义:

.menu01{
background-color:#5dc1d1;border-radius:4px;}

同理在page2.html页面定义:

.menu02{
background-color:#5dc1d1;border-radius:4px;}

在page3.html页面定义:

.menu03{
background-color:#5dc1d1;border-radius:4px;}

menu菜单这个模块是page1.html,page2.html,page3.html三个页面公共模块,通过include来共享。这样在调用不同页面时,其他链接的样式不生效。所以可以实现被点击的链接显示不同样式的效果。

但是这样的做法是非常糟糕的。同一个样式有多少个页面就重写多少次,不同class名称对应的却是同样的样式。

这样的代码我是无法忍受的。下面用一小段js来实现同样功能。

二、用js重构

代码如下:

    
starof test

三、类似的效果

实现方式如下:通过判断用户请求的url和是哪个,就给哪个添加active样式。

{% url "addpermissionurl" as theaddpermissionurl %}
新建权限 {% url "listpermissionurl" as thelistpermissionurl %}
权限列表

 

 

 

本文作者,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:有问题欢迎与我讨论,共同进步。

 

你可能感兴趣的文章
文件上传并改名
查看>>
带通配符的字符串匹配问题
查看>>
关于学习uCOS-II
查看>>
Servlet 中利用阿里云包fastjson-1.2.43.jar把map转为Json并返回前端
查看>>
我们为何要付出高昂的代价去获取智力?
查看>>
搜索 --- 数独求解 POJ 2676 Sudoku
查看>>
调用DLL
查看>>
1115. Counting Nodes in a BST (30)
查看>>
UVA 814 The Letter Carrier's Rounds(JAVA基础map)
查看>>
BZOJ5343[Ctsc2018]混合果汁——主席树+二分答案
查看>>
linux 如何降低入向收包软中断占比
查看>>
小知识点(不定更新)
查看>>
css绝对定位中的初始包含块问题
查看>>
智能指针
查看>>
phpcms导航栏多个栏目调用
查看>>
人脸识别 参考 转盒子
查看>>
SDUT OJ 顺序表应用2:多余元素删除之建表算法
查看>>
CSS
查看>>
Android笔记之为TextView设置边框
查看>>
【Lift】Scala Web 框架——Lift(一)准备工作
查看>>