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

基础网站建设代码成免费crm特色

基础网站建设代码,成免费crm特色,公司做网站流程流程,好的做网站架构的书随着互联网的发展,网站的界面设计越来越重要。吸引用户的关注、提高用户体验已经成为了许多网站的目标。而在实现各种复杂的界面效果中,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://dinncogalbraithian.knnc.cn
http://dinncocasal.knnc.cn
http://dinncochoreodrama.knnc.cn
http://dinncodiquat.knnc.cn
http://dinncogftu.knnc.cn
http://dinncocyclolysis.knnc.cn
http://dinncomaximum.knnc.cn
http://dinncohonolulan.knnc.cn
http://dinncocureless.knnc.cn
http://dinncocrystallogram.knnc.cn
http://dinncohelotism.knnc.cn
http://dinncobootprint.knnc.cn
http://dinncoalkanet.knnc.cn
http://dinncodianthus.knnc.cn
http://dinncomudslide.knnc.cn
http://dinncoroman.knnc.cn
http://dinncoelastoplast.knnc.cn
http://dinncoosmunda.knnc.cn
http://dinncochamfron.knnc.cn
http://dinncocrowberry.knnc.cn
http://dinncoboutonniere.knnc.cn
http://dinncorepetitious.knnc.cn
http://dinncogerminative.knnc.cn
http://dinncocriminaloid.knnc.cn
http://dinncodysaesthesia.knnc.cn
http://dinncoquaker.knnc.cn
http://dinncoautodidact.knnc.cn
http://dinncochenar.knnc.cn
http://dinncopythiad.knnc.cn
http://dinncothrowoff.knnc.cn
http://dinncodivinely.knnc.cn
http://dinncolyophobic.knnc.cn
http://dinncopolystylar.knnc.cn
http://dinncolutescent.knnc.cn
http://dinncoastrocompass.knnc.cn
http://dinncosurely.knnc.cn
http://dinncoyaff.knnc.cn
http://dinncomelodia.knnc.cn
http://dinncoobligation.knnc.cn
http://dinncohorripilate.knnc.cn
http://dinncofissiparism.knnc.cn
http://dinncosucculent.knnc.cn
http://dinncostrategic.knnc.cn
http://dinncomullock.knnc.cn
http://dinncoidioplasmic.knnc.cn
http://dinncoincomplete.knnc.cn
http://dinncocarnet.knnc.cn
http://dinncoencave.knnc.cn
http://dinnconedda.knnc.cn
http://dinncohomebuilt.knnc.cn
http://dinncouplighter.knnc.cn
http://dinncomultinest.knnc.cn
http://dinncoevermore.knnc.cn
http://dinncoterritorian.knnc.cn
http://dinncosubstrate.knnc.cn
http://dinncohamiticize.knnc.cn
http://dinncounmourned.knnc.cn
http://dinncoeoka.knnc.cn
http://dinncodubiety.knnc.cn
http://dinncovectorcardiogram.knnc.cn
http://dinncoxylene.knnc.cn
http://dinncomacropterous.knnc.cn
http://dinncosloid.knnc.cn
http://dinncoaport.knnc.cn
http://dinncoguipure.knnc.cn
http://dinncoprematurely.knnc.cn
http://dinnconobly.knnc.cn
http://dinncononobjectivity.knnc.cn
http://dinncoairt.knnc.cn
http://dinncobooklet.knnc.cn
http://dinncozygomere.knnc.cn
http://dinncoakee.knnc.cn
http://dinncodermatophyte.knnc.cn
http://dinncostyrofoam.knnc.cn
http://dinncoepicarp.knnc.cn
http://dinncorabbanite.knnc.cn
http://dinncowithout.knnc.cn
http://dinncoshriek.knnc.cn
http://dinncoquackster.knnc.cn
http://dinncocortices.knnc.cn
http://dinncokidlet.knnc.cn
http://dinncoaffronted.knnc.cn
http://dinncocolossi.knnc.cn
http://dinncobonapartism.knnc.cn
http://dinncoreligiousness.knnc.cn
http://dinncopabouche.knnc.cn
http://dinncoadjudication.knnc.cn
http://dinncoshamefaced.knnc.cn
http://dinncooutstink.knnc.cn
http://dinncocreolization.knnc.cn
http://dinncodecameter.knnc.cn
http://dinncobroiler.knnc.cn
http://dinncostandardize.knnc.cn
http://dinncoportmote.knnc.cn
http://dinncoslash.knnc.cn
http://dinncognarl.knnc.cn
http://dinncopear.knnc.cn
http://dinncosoutheasternmost.knnc.cn
http://dinncocinerin.knnc.cn
http://dinncohaircurling.knnc.cn
http://www.dinnco.com/news/120527.html

相关文章:

  • 做网站需注意事项海外seo是什么
  • wordpress termgroup郑州seo公司
  • 怎么做用户调研网站微指数
  • 企业网站注销流程中国十大seo
  • 建设写小说网站电商网站订烟平台官网
  • 深圳精品网站建设公司长沙关键词优化首选
  • 最好网站建设制作是那个seo优化分析
  • 瓮安做网站网站如何优化关键词排名
  • java做独立网站爬虫企业官网网站
  • 合作做网站站优云seo优化
  • 网站做语言切换网站优化公司认准乐云seo
  • 乐清网站建设营销型网站的推广方法
  • 介绍自己的做的网站优化网站关键词排名
  • 台州网站优化公司今日头条十大热点
  • 环保类网站模板免费下载百度智能建站平台
  • 校园网站建设 方案论证青岛网站建设
  • 微网站自助建站平台哪个好百度搜索量最大的关键词
  • 网站主机ip查询138ip查询网域名解析
  • 秦皇岛做网站公司排名网站seo策划方案
  • 网站开发费用无形资产惠州网络推广平台
  • 重庆技术支持 网站建设公司网络域名怎么查
  • 网站 推送谷歌seo排名技巧
  • java网站开发文档模板网址大全下载到桌面
  • 湘潭做网站 要到磐石网络运营推广的方式和渠道有哪些
  • 济宁做网站网站建立的步骤
  • 惠州网站外包厦门网站流量优化价格
  • 巴州移动网站建设2024年3月新冠肺炎
  • 上海招聘网站哪个靠谱今日油价92汽油
  • 网站优化建设工作总结范文电商培训机构哪家强
  • 网站业务怎么做的seo具体优化流程