关于data-active的问题

关于data-active的问题

http://img1.sycdn.imooc.com//climg/5f7ed28e09efddf508820444.jpg
这里为什么要用$this.addClass($this.data('active') + '-active')这种方法来给元素添加“menu-active”类?
直接写成$this.addClass('menu-active')就可以了啊
这样做有什么好处?

正在回答

登陆购买课程后可参与讨论,去登陆

3回答

同学你好。

1、在视频中老师使用的方式也是经验累积起来的,看到一个设计图,肯定会先分析一下,再查看哪一部分的效果是一样,所以就先把相同效果这个前缀固定住。如果只是做一小块的内容的话,直接使用$this.addClass('menu-active')的方法就可以了。

2、想要修改前缀是只能在html中修改了。

祝学习愉快!

好帮手慕鹤 2020-10-09 15:20:23

同学你好,这句话是老师在修改的时候忘记删除掉了,原意应该是,通过$this.data('active') 把前缀固定住,再在后面拼接需要添加的类名就可以了。

祝学习愉快!

  • 提问者 人生的起源 #1
    1、这样切图的时候要先考虑到这一步了? 2、想要修改前缀只能在html中修改了是不是? 感觉分离的不够彻底
    2020-10-09 16:04:11
好帮手慕鹤 2020-10-09 13:38:48

同学你好,在代码中,直接使用$this.addClass('menu-active')这段代码或者$this.addClass($this.data('active') + '-active')都可以实现动态添加类名的效果。在视频中,老师的这种方法,是因为html的标签中,需要添加的类名前缀是不一样的,那么在添加类名的时候,通过$this.data('active') 把前缀固定住,添加类名的之后,直接获取再拼接后缀就可以了。

祝学习愉快!

  • 提问者 人生的起源 #1
    什么叫添加类名的之后,这句看得不是很懂
    2020-10-09 14:33:14
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
组件化思想开发电商网页 18版
  • 参与学习           人
  • 提交作业       467    份
  • 解答问题       4826    个

本路径带你通过系统学习HTML5、JavaScript、jQuery的进阶知识,不仅如此,还会学习如何利用组件化的思想来开发网页,知识点+案例,使得所学可以更好的得到实践。

了解课程
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师