以前一直困惑我的一个问题就是:怎么实现给当前页面导航菜单一个样式?
最最开始的时候用的是最笨的方法,就是每个导航页面都写得不一样。比方说index.html页面的时候,会在index导航的a标签一个.active样式,然后第二个Posts.html页面的时候会在Posts导航的a标签一个.active样式。这个虽然效果实现了,但是有个很大的缺点 - 导航不能调用一个,每个页面的导航写法不一样。
后来发现可以用PHP的GET变量来实现这个效果。这个效果比上一个好,可以调用同一个导航文件,但是现在想想,这个方法会让导航这个文件代码变得臃肿,每个a标签都要写个if语句判断语句。然后根据GET获得的变量来判断是否显示.active这个样式。
今天无意中看了下一个开源的后台模板。下载下来发现他这个是纯HTML也实现了这个功能,然后查看源代码,在charisma.js文件发现了下面这个关键的代码:
|
|
然后根据这个,自己写了个Demo,果然实现了。这下省了不少代码,也解决了一个我一直以来比较困惑的问题,看来还是得多看看别人的代码,学习。
其实这样也有效果:
|
|
Comments
风逐蓝天: Good. 学习了.
风逐蓝天: $($(this))[0].href 这个是什么意思? 为什么不能是 $(this)[0].href ?
ForEcho: 这个问题我也想过,但是没搞清楚,毕竟不是专业的前端。但是我试过$(this)[0].href,结果就是行不通。你可以试着alert($(this)[0].href) 查看结果。
gao: 优化后:
|
|
ForEcho: Thx 这样写更美观了
- 原文作者: forecho
- 原文链接: https://blog.forecho.com/yong-jquery-shi-xian-dang-qian-ye-mian-gei-cai-dan-dao-hang-yi-ge-te-ding-yang-shi.html
- 版权声明:本作品采用 署名-非商业性使用 4.0 国际 (CC BY-NC 4.0)进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。