js+css如何实现换肤效果
短信预约 -IT技能 免费直播动态提醒
本篇内容介绍了“js+css如何实现换肤效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
效果图如下:
需求:点击对应小圆点,下面内容颜色跟着改变
主要思路:
在css中把对应的样式先写好;
2.获取小圆点给它绑定点击事件;
3.获取当前点击元素的类名;
4.将该类名设置给body;
js主要考察的是获取属性值和设置属性值;
<style> *{ margin:0; padding:0; list-style: none; } .dot{ margin:100px auto; display: flex; justify-content: center; } .dot li{ width: 30px; height: 30px; border-radius: 50%; cursor: pointer; } .dot li:first-child{ background:pink; } .dot li:nth-child(2){ background:green; } .dot li:nth-child(3){ background:gold; } .dot li:last-child{ background:skyblue; } .dot li:not(:last-child){ margin-right: 10px; } .content{ margin:100px auto; width: 300px; } .pink .content .banner{ height: 160px; width: 100%; background:pink; } .pink .content li{ color:pink; margin-bottom: 10px; border-bottom: 1px dashed pink; line-height: 40px; } .green .content .banner{ height: 160px; width: 100%; background:green; } .green .content li{ color:green; margin-bottom: 10px; border-bottom: 1px dashed green; line-height: 40px; } .gold .content .banner{ height: 160px; width: 100%; background:gold; } .gold .content li{ color:gold; margin-bottom: 10px; border-bottom: 1px dashed gold; line-height: 40px; } .skyblue .content .banner{ height: 160px; width: 100%; background:skyblue; } .skyblue .content li{ color:pink; margin-bottom: 10px; border-bottom: 1px dashed skyblue; line-height: 40px; }</style>
<body class="pink"> <ul class="dot"> <li class="pink"></li> <li class="green"></li> <li class="gold"></li> <li class="skyblue"></li> </ul> <div class="content"> <div class="banner"></div> <ul> <li>奶茶</li> <li>火锅</li> <li>串串</li> <li>烤肉</li> </ul> </div> <script> window.onload = function(){ let lis = document.querySelectorAll('.dot li'); let body = document.querySelector('body'); for(let i=0;i<lis.length;i++){ lis[i].addEventListener('click',function(){ // 获取属性值:元素名.属性名 设置属性值:元素名.属性名 = 属性值 ; 移除属性:元素名.属性名 = "";(此种方法不能获取,设置,移除自定义属性) //获取属性值 :元素名.getAttribute('属性名') ;设置属性值:元素名.setAttribute('属性名','属性值') ;移除属性:元素名.removeAttribute('属性名') (此种方法能获取,设置,移除自定义属性,可对任何属性有效) let color = this.getAttribute('class') body.setAttribute('class',color) }) } } </script></body>
“js+css如何实现换肤效果”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341