摘要:新建一個,解決在垂直方向上折疊的問題通過線性漸變以及畫出虛線,然后再通過將其移動到四邊。參考張哥虛線邊框教程
常常看到一種酷炫的效果,鼠標hover一片區域后,區域顯示出虛線邊框,并且還有線條動畫,那么這種效果具體是怎么實現的呢,本文提供了幾種思路僅供參考。
基本HTML
Easy-way測試測試
通過背景圖片實現。
p得垂直居中哦,還記得如何垂直居中嗎?詳見另一篇博客~
.box { width: 100px; height: 100px; position: relative; background: url(https://www.zhangxinxu.com/study/image/selection.gif); p { position: absolute; left: 0; top: 0; right: 0; bottom: 0; margin: auto; height: calc(100% - 2px); width: calc(100% - 2px); background-color: #fff; } }repeating-linear-gradient
135度repeating線性漸變,p撐開高度,白色背景覆蓋外層div漸變。
.box { width: 100px; height: 100px; background: repeating-linear-gradient( 135deg, transparent, transparent 4px, #000 4px, #000 8px ); overflow: hidden; // 新建一個BFC,解決margin在垂直方向上折疊的問題 animation: move 1s infinite linear; p { height: calc(100% - 2px); margin: 1px; background-color: #fff; } } @keyframes move { from { background-position: -1px; } to { background-position: -12px; } }linear-gradient&&background
通過線性漸變以及background-size畫出虛線,然后再通過background-position將其移動到四邊。這種方式比較好的地方在于可以分別設置四條邊的樣式以及動畫的方向,細心的同學應該會發現上一種方式的動畫并不是順時針或者逆時針方向的。
.box { width: 100px; height: 100px; background: linear-gradient(0deg, transparent 6px, #e60a0a 6px) repeat-y, linear-gradient(0deg, transparent 50%, #0f0ae8 0) repeat-y, linear-gradient(90deg, transparent 50%, #09f32f 0) repeat-x, linear-gradient(90deg, transparent 50%, #fad648 0) repeat-x; background-size: 1px 12px, 1px 12px, 12px 1px, 12px 1px; background-position: 0 0, 100% 0, 0 0, 0 100%; animation: move2 1s infinite linear; p { margin: 1px; } } @keyframes move2 { from { } to { background-position: 0 -12px, 100% 12px, 12px 0, -12px 100%; } }linear-gradient&&mask
mask屬性規范已經進入候選推薦規范之列,會說以后進入既定規范標準已經是板上釘釘的事情,大家可以放心學習,將來必有用處。
這里同樣可以使用mask來實現相同的動畫,并且可以實現虛線邊框漸變色這種效果,與background不同的是mask需要在中間加上一塊不透明的遮罩,不然p元素的內容會被遮蓋住。
.box { width: 100px; height: 100px; background: linear-gradient(0deg, #f0e, #fe0); -webkit-mask: linear-gradient(0deg, transparent 6px, #e60a0a 6px) repeat-y, linear-gradient(0deg, transparent 50%, #0f0ae8 0) repeat-y, linear-gradient(90deg, transparent 50%, #09f32f 0) repeat-x, linear-gradient(90deg, transparent 50%, #fad648 0) repeat-x, linear-gradient(0deg, #fff, #fff) no-repeat; // 這里不透明顏色隨便寫哦 -webkit-mask-size: 1px 12px, 1px 12px, 12px 1px, 12px 1px, 98px 98px; -webkit-mask-position: 0 0, 100% 0, 0 0, 0 100%, 1px 1px; overflow: hidden; animation: move3 1s infinite linear; p { height: calc(100% - 2px); margin: 1px; background-color: #fff; } } @keyframes move3 { from { } to { -webkit-mask-position: 0 -12px, 100% 12px, 12px 0, -12px 100%, 1px 1px; } }
具體demo點這里
PS今天有一個人來我們這邊面試,五年工作經驗,上來頭頭是道說自己參與過多少項目,獨自一人架構一個什么前端項目,熟練css、js、html、vue等等等,聽得我瑟瑟發抖。
然后問了個簡單的如何垂直居中,答曰:用flex;再問怎么用flex,答:不太了解;問還有什么方式,答曰:transform;再問為何transform,答:不太了解。。。
等等等,問了許多基礎的東西,大多不了解,更不用說vue的相關原理,diff算法之流。
最后問期望薪資,答:已有18k的offer,期望不要低于18k。
是我不了解行情了,還是現在壓根就不是寒冬了,拿著微薄薪水的我求個內推~~南京或杭州地區。
個人博客求友鏈~
花里胡哨電子簡歷~有時間的話可以一看。
參考張哥虛線邊框
mask教程
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114584.html
摘要:通過模糊來弱化背景和滾動提示使用兩層背景,控制交互式的圖片對比控件范圍輸入控件方式書中有很詳細的解答提醒自己要回顧。 1. 第一章 css編碼技巧 第二章 邊框與背景 半透明邊框 hsla 多重邊框 box-shadow outline 靈活的背景定位 background-position css3該屬性可以指定偏移量,////bac...
摘要:塊元素的例子內聯元素只需要必要的寬度,不強制換行。內聯元素的例子如何改變一個元素顯示可以更改內聯元素和塊元素把列表項顯示為內聯元素把元素作為塊元素定位五大屬性定位元素的默認值,即沒有定位,元素出現在正常的流中靜態定位的元素不會受到影響。?Infi-chu: http://www.cnblogs.com/Infi-chu/ ? CSS盒子模型?? ?概念:CSS盒模型本質上是一個盒子,封裝周圍...
閱讀 2516·2021-10-14 09:42
閱讀 1152·2021-09-22 15:09
閱讀 3559·2021-09-09 09:33
閱讀 3039·2021-09-07 09:59
閱讀 3652·2021-09-03 10:34
閱讀 3561·2021-07-26 22:01
閱讀 2839·2019-08-30 13:06
閱讀 1219·2019-08-30 10:48