您好,登錄后才能下訂單哦!
CSS Flex 布局如何實現無縫滾動?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
本文主要介紹了flex布局實現無縫滾動的示例代碼,分享給大家,具體如下:
案例的演示
flex布局
所謂flex布局就是彈性盒布局,這種布局在移動端比較常用,但隨著瀏覽器的版本更新,flex布局因為自身的優點,日漸常用。
思路:
首先分析這個小demo的結構,上下結構,我們可以用一個容器,將其包裹(就是所謂的大盒子)。
上方是個導航,上邊是個ul,下面我們就可以用兩個p,寬度的100%,高度自定義。
接下來我們就來開啟和模型,記住一定的父盒子哦!display:flex;,那么怎么上下分呢?在繼續添加 flex-wrap: wrap;就是上下分離了,是不是很方便。
接下來就是下邊部分了,p里嵌套了ul,而且ul的高度好理解,是p的高度,那么ul多少寬呢?,可以無限寬!!! 我們讓ul的寬度是3000px
我們接下來放li,你一看,li里面的也是上下結構,所以呢,嘿嘿!li是不是也要開啟flex呀 flex-wrap: wrap;。上方p是放img,下邊一個a標簽。
記住哦,li用浮動起來哦!并考慮overflow:hidden放在那里
動畫效果
我們有五張圖片,我們現在讓它從右向左移動。那么我們叫ul移動,帶動li移動是不是可以。
我們用@keyframes改變ul的left的值,但是問題來了,我放五張圖片,ul移動,右邊就沒了,空白了。腫么辦???
我們是不是可以將五個li,在后面再復制一份,放在后邊呀。 答案是可以的!!當我們的left正好將第一組li,移除,那么第二組就剛好不上來。那么我們用 animation: run 20s linear infinite;無限循環是不是就好了。
css部分代碼
* { margin: 0; padding: 0; } a { text-decoration: none; } .box-big { position: absolute; display: flex; left: 50%; top: 50%; border: 1px solid #9FD6FF; transform: translate(-50%, -50%); width: 707px; height: 170px; /* background-color: pink; */ flex-wrap: wrap; overflow: hidden; } .box-top { width: 707px; height: 30px; border-bottom: 1px solid #9FD6FF; background-color: #FEFEFE; } .p-bottom { width: 707px; height: 136px; /* background-color: darkgoldenrod; */ overflow: hidden; } .st-icon-android { display: inline-block; width: 15px; height: 15px; background-image: url(../img/hd.gif); margin: 8px; } h6 { position: absolute; top: 6PX; left: 30px; color: #307DD1; } ul { position: absolute; left: 90px; width: 3000px; height: 100%; animation: run 20s linear infinite; } li { list-style: none; float: left; width: 140px; height: 100%; margin: 0 5px 0 5px; /* background-color: gold; */ flex-wrap: wrap; } .photo { margin-top: 5px; width: 140px; height: 105px; text-align: center; /* background-color: springgreen; */ } p { text-align: center; } img { cursor: pointer; } @keyframes run { 0% { left: 0; } 100% { left: -745px; } }
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。