【详解JavaScript轮播图一】

2023-11-22 11:50
文章标签 java 详解 script 轮播 图一

本文主要是介绍【详解JavaScript轮播图一】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JavaScript轮播图一在这里插入图片描述源码分析

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>body{margin: 0;padding: 0;}.carousel{width: 100%;height: 33.3vw;position: relative;left: 0;top: 0;font-size: 0;min-width: 1000px;}.carousel>.img-con{width: 100%;height: 100%;position: absolute;left: 0;top: 0;opacity: 0;transition:  all 0.5s;}.carousel>.img-con>img{width: 100%;height: 100%;position: absolute;left: 0;top: 0;}.carousel>.img-con>div{position: absolute;left:10vw;top: 2vw;font-size: 20px;color: white;}.carousel>.img-con>div>span>i{font-style:normal;font-size: 28px;}.carousel>.img-con>div>h1{font-size: 20px;}ul{position: absolute;right: 50px;top:50%;transform: translate(0,-50%);list-style: none;margin: 0;padding: 0;}ul>li{margin-top: 1vw; }ul>li img{border:2px solid transparent;}ul>li:first-child{margin-top: 0;}</style>
</head>
<body><div class="carousel"><div class="img-con" id="a"><img src="./img/a.jpg"><div><span><i>28</i>/Jul.2022</span><h1>与父母的47天自驾游|向疆而行2万里,我们依旧是过客</h1></div></div><div class="img-con" id="b"><img src="./img/b.jpg"><div><span><i>27</i>/Jul.2022</span><h1>自驾川西小环线,在千碉之国遇见梨花如雪的季节</h1></div></div><div class="img-con" id="c"><img src="./img/c.jpg"><div><span><i>26</i>/Jul.2022</span><h1>被误解的沙县,原来有这么多美食只有在当地才能吃到!</h1></div></div><div class="img-con" id="d"><img src="./img/d.jpg"><div><span><i>25</i>/Jul.2022</span><h1>周末出逃计划 | 打卡美丽中国</h1></div></div><div class="img-con" id="e"><img src="./img/e.jpg"><div><span><i>24</i>/Jul.2022</span><h1>寻迹山川湖海,邂逅云南的冬与夏</h1></div></div><ul><li><a href="#a"><img src="./img/a_icon.png"></a></li><li><a href="#b"><img src="./img/b_icon.png"></a></li><li><a href="#c"><img src="./img/c_icon.png"></a></li><li><a href="#d"><img src="./img/d_icon.png"></a></li><li><a href="#e"><img src="./img/e_icon.png"></a></li></ul></div><script>var imgPrev,ul,iconPrev;init();function init(){// 获取ulul=document.querySelector("ul");// 侦听hashchange事件window.addEventListener("hashchange",hashChangeHandler);// 判断当前页面的地址栏中是否有hash值var index=["#a","#b","#c","#d","#e"].indexOf(location.hash);// 如果没有就给当前页面增加hash值是#a,这样就会触发hashchange事件if(index===-1) location.href+="#a"; else hashChangeHandler();// 如果已经有hash,证明当前刷新了页面,但是hash发生改变,手动调用切换动画}// 当hashchange变化时,执行这个方法function hashChangeHandler(e){// 获取当前页面中的hash值去除#var id=location.hash.slice(1);// 根据当前hash值查找到对应id的img-con的元素,并且切换这个元素的opacity属性imgPrev=changePrev(imgPrev,document.getElementById(id),"opacity",0,1);// 获取当前hash值对应的下标var index=["#a","#b","#c","#d","#e"].indexOf(location.hash);// 切换对应下标所指的小图标的边框线颜色iconPrev=changePrev(iconPrev,ul.children[index].firstElementChild.firstElementChild,"borderColor","transparent","#ff9d00")}/* 切换函数prev 上一次切换的元素elem 本次要切换的元素prop 要切换的样式属性value1 原始样式值value2 要切换的样式值*/function changePrev(prev,elem,prop,value1,value2){// 如果上次切换的元素存在时if(prev){// 设置上次的切换元素样式为原始样式prev.style[prop]=value1;}// 修改本次要切换元素的样式值elem.style[prop]=value2;// 返回本次被切换的元素,这个元素返回到外面时将会赋值给对应的prev元素return elem;}</script>
</body>
</html>

这篇关于【详解JavaScript轮播图一】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/409925

相关文章

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B