纯CSS实现单击锚点平滑切换的效果
22.50注:貌似自己错的有点离谱了o(╯□╰)o 大家先别看了
有时想实现一个功能,比如想让页面不出现滚动条,但是却能装下更多的东西,这个时候我们会对某个容器设置overflow: hidden,然后通过锚点来实现单击切换页面(其实只是控制显示的内容)的效果。但是通过锚点来跳到指定内容的不足之处在于,没有什么过渡效果,很突兀的就跳到了目标点。当然,也可以通过JS或者jQuery来实现自己想要的动态切换效果,这一类的文章一搜一大堆,这里就不赘述了。
但是在一些个人主页中,比如github的个人主页(只是主页而已,也就是username.github.io)上会禁止JS脚本的运行,这个时候如果还是想通过单击锚点平滑切换的功能的话,应该怎么办呢?
原谅我是一个前端初学者,傻想了很久也想不到什么办法,然后就百度谷歌了。
后来找到了一些方法,比如用radio配合他的check属性来实现,文章在这里,关于这个方法,慕课上也有专门的教程,大家也可以去看看。
但是可不可以不插入radio就实现对应的效果呢? 答案是有的。
那就是利用:target伪类,这个选择器可以选择当前活动的锚点,那么利用这个属性我们就可以实现自己想要的效果了。
代码如下:
<a href="#tag1">Tag1</a><a href="#tag2">Tag2</a><a href="#tag3">Tag3</a><div id="container"> <div id="tag1"></div> <div id="tag2"></div> <div id="tag3"></div></div>
div{ width: 100px; height: 100px; border-radius: 50%;}#container{ margin-top: 10px; outline: 1px solid red; position: relative;}#tag1,#tag2,#tag3{ transition: all ease-out .2s; position: absolute; top:0 left:0; right:0; bottom:0; opacity: 0; }#tag1{ background: #f66; opacity: 1; z-index: 1;}#tag2{ background: orange;}#tag3{ background: gray;}#container>div:target{ z-index: 1000; opacity: 1;}
查看DEMO
上面的例子是通过绝对定位配合z-index和透明度来实现的动态效果。先将所有的元素的opacity设为0,然后为了默认显示出来第一个元素,所以第一个元素的opacity为1,z-index为1。然后单击就可以实现动态切换了。
其实我最先尝试的是通过给#container设置overflow: hidden;, 为它的子元素设置height:100%;,然后给target设置margin-top为负的百分比值来实现相应效果的,毕竟比较喜欢这种从下往上冒或者从上往下掉的感觉嘛。。。但是在实现过程中遇到了一点小问题,那就是当Tag2和Tag3相互切换的时候,居然只会移动到一半就不再动了,如果把overflow: hidden去掉,显示的就是自己期望的效果。一个有问题的DEMO
后来自己想到了解决的办法,那就是给container包裹一个div,然后把overflow: hidden设置在这个元素身上,再把container的overflow去掉,设置高度为它子元素的高度,这样就能显示正常了。 DEMO在这里.
虽然找到了解决办法,但是对于问题DEMO 里的这种怪异行为真的不理解,如果各位谁知道的话,还请告知,谢谢。
参见:
stackoverflow - 纯CSS滚动效果

HTML是一種用於構建網頁的語言,通過標籤和屬性定義網頁結構和內容。 1)HTML通過標籤組織文檔結構,如、。 2)瀏覽器解析HTML構建DOM並渲染網頁。 3)HTML5的新特性如、、增強了多媒體功能。 4)常見錯誤包括標籤未閉合和屬性值未加引號。 5)優化建議包括使用語義化標籤和減少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代碼” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代碼”代碼“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML、CSS和JavaScript是Web開發的三大支柱。 1.HTML定義網頁結構,使用標籤如、等。 2.CSS控製網頁樣式,使用選擇器和屬性如color、font-size等。 3.JavaScript實現動態效果和交互,通過事件監聽和DOM操作。

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

HTML適合初學者學習,因為它簡單易學且能快速看到成果。 1)HTML的學習曲線平緩,易於上手。 2)只需掌握基本標籤即可開始創建網頁。 3)靈活性高,可與CSS和JavaScript結合使用。 4)豐富的學習資源和現代工具支持學習過程。

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用