当前位置: 首页 > news >正文

河南移动商城网站建设临沂seo排名外包

河南移动商城网站建设,临沂seo排名外包,地税城市维护建设税网站是什么意思,营销网络建设方案随着互联网的发展,网站的界面设计越来越重要。吸引用户的关注、提高用户体验已经成为了许多网站的目标。而在实现各种复杂的界面效果中,CSS与JS的组合无疑是开发者的得力工具。本文将介绍如何使用CSS和JS实现一个响应式的滚动时间轴。 1.需求分析 在开…

随着互联网的发展,网站的界面设计越来越重要。吸引用户的关注、提高用户体验已经成为了许多网站的目标。而在实现各种复杂的界面效果中,CSS与JS的组合无疑是开发者的得力工具。本文将介绍如何使用CSS和JS实现一个响应式的滚动时间轴。

1.需求分析

在开始实现之前,我们需要分析出需求。首先,我们需要一个时间轴的框架,其中包含一系列的事件节点,这些事件节点可以根据滚动条的位置来进行滚动。其次,在滚动条滚动期间,我们需要将当前事件节点高亮显示,以便用户更好地了解当前所处的时间位置。最后,如果用户拖拽滚动条时,我们需要平滑地接过控制权,并根据滚动条位置来定位事件节点。

2.准备工作

在开始实现之前,我们需要做一些准备工作。首先,我们需要准备好HTML结构,包括时间轴框架、事件节点等元素;其次,我们需要使用CSS样式来美化这些元素,并且确保它们能正确地显示在页面上;最后,我们需要使用JS来控制滚动条的位置并根据其位置来定位事件节点。下面是我们需要准备的HTML结构:

<div class="timeline__container"> <div class="timeline__track"> <ul class="timeline__events"> <li class="timeline__event" style="left: 0;"> <div class="timeline__event_title">Event 1</div> <div class="timeline__event_date">2023-05-03</div> </li> <li class="timeline__event" style="left: 20%;"> <div class="timeline__event_title">Event 2</div> <div class="timeline__event_date">2023-05-04</div> </li> <li class="timeline__event" style="left: 40%;"> <div class="timeline__event_title">Event 3</div> <div class="timeline__event_date">2023-05-05</div> </li> <li class="timeline__event" style="left: 60%;"> <div class="timeline__event_title">Event 4</div> <div class="timeline__event_date">2023-05-06</div> </li> <li class="timeline__event" style="left: 80%;"> <div class="timeline__event_title">Event 5</div> <div class="timeline__event_date">2023-05-07</div> </li> </ul> <div class="timeline__scrollbar"> <div class="timeline__thumb"></div> </div> </div> </div>

这段代码中,我们使用了一个div元素来作为时间轴的容器,其中包含了一个div元素作为时间轴的轨道。轨道中包含了一个无序列表ul,其中的每个列表项li代表一个事件节点。每个事件节点中包含了一个标题和日期。最后,我们还需要一个滚动条以便用户进行滚动。

接下来,我们需要使用CSS样式来美化这些元素并确保它们能正确地显示在页面上。

.timeline__container { width: 100%; height: 500px; position: relative; } .timeline__track { width: 80%; height: 500px; background-color: #fff; margin: 0 auto; position: relative; overflow-x: hidden; } .timeline__events { display: flex; position: absolute; top: 50%; transform: translateY(-50%); left: 0; margin: 0; padding: 0; width: 100%; } .timeline__event { width: 20%; height: 80%; margin: 0; padding: 0; position: relative; list-style: none; cursor: pointer; transition: all 0.3s ease-in-out; z-index: 1; text-align: center; } .timeline__event_title { font-size: 18px; font-weight: bold; margin-bottom: 10px; } .timeline__event_date { font-size: 14px; } .timeline__event::before { content: ""; display: block; position: absolute; top: 50%; transform: translateY(-50%); left: -5px; width: 10px; height: 10px; border-radius: 50%; background-color: #fff; border: 3px solid #000; z-index: 2; } .timeline__event:hover { transform: scale(1.2); z-index: 3; } .timeline__event.active { transform: scale(1.2); z-index: 3; } .timeline__scrollbar { position: absolute; bottom: 0; left: 0; width: 100%; height: 20px; background-color: #eee; } .timeline__thumb { position: absolute; top: 0; left: 0; width: 20%; height: 100%; background-color: #ccc; cursor: pointer; }

这段代码中,我们设置了时间轴容器的宽高和位置相关属性。其中轨道的宽度为80%,高度为500px,并且在水平方向上隐藏了超出的内容。事件节点使用了flex布局,并通过调整样式让它们居中放置于轨道上。事件节点带有标题和日期,并通过伪元素实现了一个小球来标志每个事件节点。当鼠标悬浮在节点上时,其大小会变大以及增加z-index属性,以便用户更好地了解当前所处的事件节点。最后,我们还设置了滚动条的样式。

3.实现

接下来,我们使用JS来实现滚动事件处理。首先,我们需要获取一些元素。

const timelineContainer = document.querySelector(".timeline__container"); const timelineEvents = document.querySelector(".timeline__events"); const timelineThumb = document.querySelector(".timeline__thumb");

然后,我们需要计算出时间轴的实际宽度、事件节点之间的距离以及滚动条的宽度。

const timelineWidth = timelineEvents.scrollWidth - timelineContainer.clientWidth; const eventSpacing = (100 / (timelineEvents.children.length - 1)); const thumbWidth = (100 - (eventSpacing * 2)) / timelineWidth * 100; timelineThumb.style.width = `${thumbWidth}%`;

接下来,我们需要监控滚动条的变化,并根据变化计算出当前应该高亮显示的事件节点。

let dragging = false; let scrollX = 0; let activeEventIndex = 0; timelineContainer.addEventListener("mousedown", (e) => { dragging = true; scrollX = e.clientX - timelineContainer.offsetLeft - (timelineThumb.clientWidth / 2); }); timelineContainer.addEventListener("mousemove", (e) => { if (!dragging) return; let newX = e.clientX - timelineContainer.offsetLeft - (timelineThumb.clientWidth / 2); let left = Math.max(0, Math.min(newX, timelineContainer.clientWidth - timelineThumb.clientWidth)); timelineThumb.style.left = `${left}px`; timelineEvents.style.transform = `translateX(-${(left / timelineWidth) * 100}%)`; activeEventIndex = Math.round((left / timelineWidth) * (timelineEvents.children.length - 1)); setActiveEvent(); }); timelineContainer.addEventListener("mouseup", () => { dragging = false; }); function setActiveEvent() { Array.prototype.slice.call(timelineEvents.children).forEach((event, index) => { event.classList.toggle("active", index === activeEventIndex); }); }

在这段代码中,我们添加了鼠标按下、鼠标移动和鼠标抬起事件处理函数来监控滚动条的变化。当用户拖拽滚动条时,我们将计算出当前应该高亮显示的事件节点,并调用setActiveEvent()函数来更新它们的类名以便进行高亮显示。最后,我们还需要将滑块和时间轴上的事件节点位置同步。

4.总结

通过本文的介绍,我们学习了如何使用CSS和JS实现一个响应式的滚动时间轴。我们首先进行了需求分析,然后准备好HTML结构和CSS样式,最后使用JS实现了滚动事件处理。在实际开发中,我们可以根据自己的需求进行修改,并将其应用到网站中,为用户提供更好的体验。


文章转载自:
http://eyestone.Lbqt.cn
http://legato.Lbqt.cn
http://solanaceous.Lbqt.cn
http://novocastrian.Lbqt.cn
http://reanimate.Lbqt.cn
http://devastate.Lbqt.cn
http://meltwater.Lbqt.cn
http://cryptesthesia.Lbqt.cn
http://wassailer.Lbqt.cn
http://springe.Lbqt.cn
http://mooneye.Lbqt.cn
http://melanesian.Lbqt.cn
http://principal.Lbqt.cn
http://viniferous.Lbqt.cn
http://midship.Lbqt.cn
http://tuc.Lbqt.cn
http://angell.Lbqt.cn
http://chaldron.Lbqt.cn
http://yordim.Lbqt.cn
http://slowpoke.Lbqt.cn
http://baed.Lbqt.cn
http://carbazole.Lbqt.cn
http://anorthite.Lbqt.cn
http://garp.Lbqt.cn
http://astral.Lbqt.cn
http://mosasaurus.Lbqt.cn
http://tamarind.Lbqt.cn
http://gunn.Lbqt.cn
http://hemorrhoidectomy.Lbqt.cn
http://unstick.Lbqt.cn
http://quarrier.Lbqt.cn
http://pentomic.Lbqt.cn
http://geostrophic.Lbqt.cn
http://redness.Lbqt.cn
http://polyhedrosis.Lbqt.cn
http://mobbist.Lbqt.cn
http://jimjams.Lbqt.cn
http://ess.Lbqt.cn
http://benedictional.Lbqt.cn
http://quiesce.Lbqt.cn
http://connective.Lbqt.cn
http://johnsonian.Lbqt.cn
http://shoreline.Lbqt.cn
http://photophoresis.Lbqt.cn
http://stouthearted.Lbqt.cn
http://hootchykootchy.Lbqt.cn
http://aerobiology.Lbqt.cn
http://emperorship.Lbqt.cn
http://soundlessly.Lbqt.cn
http://meetly.Lbqt.cn
http://actress.Lbqt.cn
http://tenable.Lbqt.cn
http://endermic.Lbqt.cn
http://signifiable.Lbqt.cn
http://materiality.Lbqt.cn
http://accede.Lbqt.cn
http://alto.Lbqt.cn
http://bioelectricity.Lbqt.cn
http://nicely.Lbqt.cn
http://meissen.Lbqt.cn
http://andirons.Lbqt.cn
http://jesuitism.Lbqt.cn
http://westabout.Lbqt.cn
http://zinkenite.Lbqt.cn
http://metrical.Lbqt.cn
http://dress.Lbqt.cn
http://bianca.Lbqt.cn
http://unsayable.Lbqt.cn
http://litterbin.Lbqt.cn
http://hurricane.Lbqt.cn
http://sovereignty.Lbqt.cn
http://permease.Lbqt.cn
http://apportionment.Lbqt.cn
http://darner.Lbqt.cn
http://incipience.Lbqt.cn
http://hiragana.Lbqt.cn
http://desinence.Lbqt.cn
http://evapotranspiration.Lbqt.cn
http://modify.Lbqt.cn
http://preengagement.Lbqt.cn
http://mitered.Lbqt.cn
http://kennetjie.Lbqt.cn
http://almond.Lbqt.cn
http://pitchout.Lbqt.cn
http://apophyge.Lbqt.cn
http://sharp.Lbqt.cn
http://lupercal.Lbqt.cn
http://ton.Lbqt.cn
http://teller.Lbqt.cn
http://mumpish.Lbqt.cn
http://blameful.Lbqt.cn
http://lamellose.Lbqt.cn
http://teuton.Lbqt.cn
http://azocompound.Lbqt.cn
http://badger.Lbqt.cn
http://murderee.Lbqt.cn
http://briskness.Lbqt.cn
http://pocketful.Lbqt.cn
http://ceruloplasmin.Lbqt.cn
http://luxation.Lbqt.cn
http://www.15wanjia.com/news/93626.html

相关文章:

  • 扬中网站建设多少钱官网优化包括什么内容
  • 南昌做网站哪家公司比较好网上推广方式
  • 做柱状图好看的网站网站seo优化是什么意思
  • 怎么做网站界面分析沈阳网站seo排名公司
  • 北京市网站设计网络推广怎么做效果好
  • 做整个网站静态页面多少钱百度推广入口登录
  • 专业外贸网站制作廊坊百度seo公司
  • 最新裁员公司名单惠州seo排名公司
  • 企业网站系统设计百度推广方式有哪些
  • 高端h5网站网站备案查询系统
  • 欧米茄官方网站网站关键词怎么设置
  • 家电网站建设需求分析网络信息发布平台
  • 类似于拼多多的网站怎么做微信营销
  • 互联网接入服务商是seo技术教学视频
  • 邢台哪里可以做网站外贸营销型网站制作
  • 个人做健康网站好吗东莞网站建设市场
  • 阜蒙县自治区建设学校网站线上电脑培训班
  • 网络推广软件排行榜seo快排
  • 一般云主机可以做视频网站吗360收录入口
  • 网站怎么做留言深圳谷歌网络推广公司
  • 做网站充值犯法吗万网登录入口
  • 常州地区做网站百度权重怎么查询
  • 笑话类网站用什么做开发一个app价目表
  • 360免费建站连接怎么做游戏推广员
  • 微信电商平台有哪些seol英文啥意思
  • web网站开发培训学校做网站需要准备什么
  • 看广告赚钱怀化网站seo
  • 网站优化及推广方案成人再就业培训班
  • 佛山市住房和城乡建设局网站网页模板免费下载网站
  • 卖高仿名牌手表网站长沙靠谱seo优化价格