JS实现网站换肤

 更新时间:2022年07月01日 16:19:45   作者:锅大虾  
这篇文章主要为大家详细介绍了JS实现网站换肤,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了JS实现网站换肤的具体代码,供大家参考,具体内容如下

先看效果

1、左侧是待选择的图片列表
2、点击对应图片自动为当前网站换背景图片
3、为当前选择的图片加个2px的border

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>网站换肤</title>
    <style>
        body {
            background: url(images/abc-123.jpg) no-repeat center;
        }
        ul li {
            list-style: none;
        }
        .baidu img {
            width: 100px;
        }
        .baidu li:hover img {
            border: 1px solid red;
        }
    </style>
</head>
<body>
    <ul class="baidu">
        <li><img src="images/Colorful-Abstraction01.jpg" alt=""></li>
        <li><img src="images/Colorful-Abstraction02.jpg" alt=""></li>
        <li><img src="images/Colorful-Abstraction03.jpg" alt=""></li>
        <li><img src="images/abc-123.jpg" alt=""></li>
    </ul>
    <script>
        // 获取元素
        var imgs = document.querySelectorAll("img");
        // 注册事件并处理
        for(var i = 0; i < imgs.length; i++){
            imgs[i].onclick = function(){
                document.body.style.backgroundImage = "url(" + this.src + ")";
                for(var i = 0; i < imgs.length; i++){
                    imgs[i].style.border = "none";
                }
                this.style.border = "2px solid red";
            }
        }
    </script>
</body>
</html>

×为当前选择的图片加2px边框前,需要使用for循环初始化所有图片的边框,不然点击一个就会产生一个边框。

for(var i = 0; i < imgs.length; i++){
    imgs[i].style.border = "none";
}

接着再为当前选择的图片加上边框

this.style.border = "2px solid red";

×为body更换背景图片时,需要注意css的写法backgroundImage, 且还需注意js中字符换和变量的拼接方法

document.body.style.backgroundImage = "url(" + this.src + ")"

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • js几秒以后倒计时跳转示例

    js几秒以后倒计时跳转示例

    使用js实现几秒以后倒计时跳转,这个在某些特殊情况下还是比较实用的,下面为大家介绍下具体的实现步骤,感兴趣的朋友不要错过
    2013-12-12
  • 微信小程序系列之自定义顶部导航功能

    微信小程序系列之自定义顶部导航功能

    这篇文章主要介绍了微信小程序系列之自定义顶部导航功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • javascript用defineProperty实现简单的双向绑定方法

    javascript用defineProperty实现简单的双向绑定方法

    这篇文章主要介绍了javascript用defineProperty实现简单的双向绑定方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • js blob类型url的视频下载问题的解决

    js blob类型url的视频下载问题的解决

    这篇文章主要介绍了js blob类型url的视频下载问题的解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • 关于在LayUI中使用AJAX提交巨坑记录

    关于在LayUI中使用AJAX提交巨坑记录

    今天小编就为大家分享一篇关于在LayUI中使用AJAX提交巨坑记录,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • 一文详解JS 类型转换方法以及如何避免隐式转换

    一文详解JS 类型转换方法以及如何避免隐式转换

    这篇文章主要为大家介绍了JS 类型转换方法以及如何避免隐式转换示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Bootstrap精简教程中秋大放送

    Bootstrap精简教程中秋大放送

    Bootstrap精简教程中秋大放送,这篇文章主要为大家分享了最基础的Bootstrap学习教程,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • 微信小程序wxml不能使用Array.includes条件判断解决方法

    微信小程序wxml不能使用Array.includes条件判断解决方法

    这篇文章主要为大家介绍了微信小程序wxml不能使用Array.includes条件判断解决方法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-11-11
  • 微信小程序中富文本编辑器的实现

    微信小程序中富文本编辑器的实现

    富文本编辑器不同于文本编辑器,程序员可到网上下载免费的富文本编辑器内嵌于自己的网站或程序里。本文将详解一下微信小程序中富文本编辑器的实现与使用,需要的可以参考一下
    2022-06-06
  • JavaScript相等运算符的九条规则示例详解

    JavaScript相等运算符的九条规则示例详解

    这篇文章主要给大家介绍了关于JavaScript相等运算符的九条规则,文中通过示例代码介绍的非常详细,对大家的学习或者使用JavaScript具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10

最新评论