亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
HTML結(jié)構(gòu)
基礎(chǔ)樣式
創(chuàng)建獨(dú)特的三角形形狀
方法一:邊框方法
方法二:背景圖像方法
首頁(yè) web前端 css教學(xué) 哦,製作三角形麵包絲帶的許多方法!

哦,製作三角形麵包絲帶的許多方法!

Apr 21, 2025 am 11:26 AM

Oh, the Many Ways to Make Triangular Breadcrumb Ribbons!

多種製作三角形麵包屑條帶的方法

本文探討如何創(chuàng)建一系列相互連接的鏈接,它們呈現(xiàn)出類似於階梯式麵包屑導(dǎo)航中所見的V形形狀和每個(gè)區(qū)塊上的凹口。

這種樣式在網(wǎng)頁(yè)設(shè)計(jì)中很常見,例如多步驟表單和網(wǎng)站麵包屑導(dǎo)航。我們將這些樣式稱為“條帶”,以便於理解。

與許多網(wǎng)頁(yè)元素一樣,我們可以通過(guò)多種方法創(chuàng)建這些條帶!我創(chuàng)建了一個(gè)演示頁(yè)面,其中包含多種方法,例如使用CSS三角形、SVG背景和CSS clip-path屬性。

HTML結(jié)構(gòu)

每個(gè)演示的HTML結(jié)構(gòu)基本相同,包含一個(gè)充當(dāng)父元素的<nav></nav>元素和作為子元素的鏈接。

<nav aria-label="breadcrumbs" role="navigation"><a href="http://ipnx.cn/link/3dc023ccc7e0bd23ce2d4427756fd03c">主頁(yè)</a>
  <a href="http://ipnx.cn/link/3dc023ccc7e0bd23ce2d4427756fd03ccategories/articles/">部落格</a>
  <a aria-current="page" href="http://ipnx.cn/link/3dc023ccc7e0bd23ce2d4427756fd03carticles/building-an-animated-sticky-header-with-custom-offset/">文章</a>
</nav>

請(qǐng)注意,根據(jù)A11y Style Guide網(wǎng)站,這些元素應(yīng)符合無(wú)障礙性標(biāo)準(zhǔn)。在設(shè)計(jì)組件時(shí),務(wù)必考慮無(wú)障礙性,並在一開始就引入無(wú)障礙性是避免出現(xiàn)“忘記添加無(wú)障礙性”問(wèn)題的最佳方法。

基礎(chǔ)樣式

對(duì)於這類樣式,我們需要確保元素大小正確。為此,我們將定義.ribbon (我們將這些元素稱為“條帶”)包裝元素的字體大小,然後在子元素(鏈接)上使用em單位。

 /* 定義包裝元素的字體大小*/
.ribbon {
  font-size: 15px;
}

/* 使用em單位定義條帶元素的大小*/
.ribbon__element {
  font-size: 1.5em;
  letter-spacing: 0.01em;
  line-height: 1.333em;
  padding: 0.667em 0.667em 0.667em 1.333em;
}

這種技術(shù)有利於定義每個(gè)條帶的三角形形狀大小,因?yàn)槲覀儗⑹褂孟嗤拇笮?lái)計(jì)算三角形。由於我們使用em單位來(lái)計(jì)算條帶元素的大小,我們可以通過(guò)重新定義包裝元素的字體大小來(lái)調(diào)整所有元素的大小。

讓我們使用CSS Grid進(jìn)行佈局,因?yàn)槲覀兛梢赃@樣做。我們可以使用更廣泛支持瀏覽器的方法來(lái)實(shí)現(xiàn),但這取決於您的支持需求。

我們將定義四列:

  • 三列用於條帶元素
  • 一列用於解決間距問(wèn)題。按原樣,右箭頭形狀將放置在條帶組件的外部,這可能會(huì)弄亂原始佈局。
 /* 包裝元素* 我們使用CSS Grid,但請(qǐng)確保它符合您的瀏覽器支持要求。
 * 假設(shè)使用autoprefixer進(jìn)行供應(yīng)商前綴和屬性。
 */

.ribbon {
  display: grid;
  grid-gap: 1px;
  grid-template-columns: repeat(auto-fill, 1fr) 1em; /* 自動(dòng)填充三個(gè)條帶元素加上一列窄列以解決大小問(wèn)題*/
}

如果您希望避免拉伸條帶元素,則可以不同地定義網(wǎng)格。例如,我們可以使用max-content根據(jù)內(nèi)容大小調(diào)整列。 (但是,請(qǐng)注意, max-content在某些主要瀏覽器中尚不支持。)

 /* 使條帶列根據(jù)最大內(nèi)容大小調(diào)整*/
.ribbon--auto {
  grid-template-columns: repeat(3, max-content) 1em;
}

我相信有很多不同的方法可以進(jìn)行佈局。我喜歡這種方法,因?yàn)樗x了條帶元素之間的確切間隙,無(wú)需複雜的計(jì)算。

無(wú)障礙性不僅僅是添加aria屬性。它還包括顏色對(duì)比度和可讀性,以及添加懸停和焦點(diǎn)狀態(tài)。如果您不喜歡輪廓樣式,可以使用其他CSS屬性,例如box-shadow。

 /* 使用當(dāng)前鏈接顏色,但在懸停時(shí)添加下劃線*/
.ribbon__element:hover,
.ribbon__element:active {
  color: inherit;
  text-decoration: underline;
}

/* 清除默認(rèn)輪廓樣式並使用內(nèi)嵌盒陰影表示焦點(diǎn)狀態(tài)*/
.ribbon__element:focus {
  box-shadow: inset 0 -3px 0 0 #343435;
  outline: none;
}

創(chuàng)建獨(dú)特的三角形形狀

在定義每個(gè)條帶末尾的三角形時(shí),我們有多種選擇。我們可以:

  1. 使用偽元素和邊框創(chuàng)建三角形
  2. 在偽元素上使用SVG背景圖像
  3. 使用內(nèi)聯(lián)SVG圖像
  4. 使用polygon()函數(shù)創(chuàng)建clip-path

讓我們深入研究每一個(gè)。

方法一:邊框方法

首先,我們應(yīng)該將元素的寬度和高度設(shè)置為零,這樣它就不會(huì)妨礙我們用來(lái)繪製三角形的偽元素。然後,我們應(yīng)該使用邊框繪製三角形,具體來(lái)說(shuō),是定義與背景顏色匹配的實(shí)心左邊框,使其與條帶的其餘部分融合。接下來(lái),讓我們定義頂部和底部邊框,並將其設(shè)置為透明。這裡的技巧是計(jì)算邊框的大小。

我們的條帶元素的內(nèi)容大小為行高值加上頂部和底部填充:

 <code>1.333em 0.667em 0.667em = 2.667em</code>

這意味著我們的頂部和底部邊框應(yīng)該為此大小的一半。唯一剩下的就是將元素絕對(duì)定位到組件的正確側(cè)邊。

 /* 左箭頭*/
.ribbon--alpha .ribbon__element:before {
  /* 使內(nèi)容大小為零*/
  content: '';
  height: 0;
  width: 0;

  /* 使用邊框使偽元素適合條帶大小*/
  border-bottom: 1.333em solid transparent;
  border-left: 0.667em solid #fff;
  border-top: 1.333em solid transparent;

  /* 將元素絕對(duì)定位在條帶元素的左側(cè)*/
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
}

/* 右箭頭*/
.ribbon--alpha .ribbon__element:after {
  /* 使內(nèi)容大小為零*/
  content: '';
  height: 0;
  width: 0;

  /* 使用邊框使偽元素適合條帶大小*/
  border-bottom: 1.333em solid transparent;
  border-left: 0.667em solid;
  border-top: 1.333em solid transparent;

  /* 將元素絕對(duì)定位在條帶元素的右側(cè)並將其推到外部*/
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  -webkit-transform: translateX(0.667em);
  transform: translateX(0.667em);
}

由於右三角形應(yīng)與條帶的背景顏色匹配,因此請(qǐng)記住為每個(gè)條帶的偽元素添加正確的邊框顏色。

 /* 第一個(gè)元素的右箭頭*/
.ribbon--alpha .ribbon__element:nth-child(1):after {
  border-left-color: #11d295;
}

/* 第二個(gè)元素的右箭頭*/
.ribbon--alpha .ribbon__element:nth-child(2):after {
  border-left-color: #ef3675;
}

/* 第三個(gè)元素的右箭頭*/
.ribbon--alpha .ribbon__element:nth-child(3):after {
  border-left-color: #4cd4e9;
}

就是這樣!

方法二:背景圖像方法

我們還可以使用背景圖像創(chuàng)建三角形。這需要?jiǎng)?chuàng)建與設(shè)計(jì)匹配的圖像,這有點(diǎn)麻煩,但仍然完全有可能。我們將在這裡使用SVG,因?yàn)樗谌魏畏直媛氏露己芰鲿场?/p>

與邊框三角形方法不同,我們希望將偽元素的高度與條帶元素的高度(或100%)匹配。組件的寬度應(yīng)與邊框三角形的左邊界寬度匹配,在我們的例子中為0.666666em。然後,我們應(yīng)該在左側(cè)三角形上使用白色三角形作為背景圖像,然後在右側(cè)三角形上使用彩色三角形圖像。同樣,我們使用絕對(duì)定位將三角形放置到條帶元素的正確側(cè)邊。

 /* 左箭頭*/
.ribbon--beta .ribbon__element:before {
  /* 定義箭頭大小*/
  content: '';
  height: 100%;
  width: 0.666666em;

  /* 定義與背景顏色匹配的背景圖像*/
  background-image: url(data:image/svg xml;base64,PHN2ZyBoZWlnaHQ9IjQwIiB2aWV3Qm94PSIwIDAgMTAgNDAiIHdpZHRoPSIxMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiBmaWxsPSI jZmZmIj48cGF0aCBkPSJtNSAxNSAyMCAxMGgtNDB6IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KDAgLTEgLTEgMCAyNSAyNSkiLz48L3N2Zz4=);
  background-position: center left;
  background-repeat: no-repeat;
  background-size: 100%;

  /* 將元素絕對(duì)定位在條帶元素的左側(cè)*/
  position: absolute;
  bottom: 0;
  top: 0;
  left: 0;
}

/* 右箭頭*/
.ribbon--beta .ribbon__element:after {
  /* 定義箭頭大小*/
  content: '';
  height: 100%;
  width: 0.667em;

  /* 定義背景圖像屬性*/
  background-position: center left;
  background-repeat: no-repeat;
  background-size: 100%;

  /* 將元素絕對(duì)定位在條帶元素的右側(cè)並將其推到外部*/
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  -webkit-transform: translateX(0.667em);
  transform: translateX(0.667em);
}

/* 定義與第一個(gè)元素的背景顏色匹配的背景圖像*/
.ribbon--beta .ribbon__element:nth-child(1):after {
  background-image: url(data:image/svg xml;base64,PHN2ZyBoZWlnaHQ9IjQwIiB2aWV3Qm94PSIwIDAgMTAgNDAiIHdpZHRoPSIxMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkP SJtNSAxNSAyMCAxMGgtNDB6IiBmaWxsPSIjMTFkMjk1IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KDAgLTEgLTEgMCAyNSAyNSkiLz48L3N2Zz4=);
}

/* 定義與第二個(gè)元素的背景顏色匹配的背景圖像*/
.ribbon--beta .ribbon__element:nth-child(2):after {
  background-image: url(data:image/svg xml;base64,PHN2ZyBoZWlnaHQ9IjQwIiB2aWV3Qm94PSIwIDAgMTAgNDAiIHdpZHRoPSIxMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkP SJtNSAxNSAyMCAxMGgtNDB6IiBmaWxsPSIjZWYzNjc1IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KDAgLTEgLTEgMCAyNSAyNSkiLz48L3N2Zz4=);
}

/* 定義與第三個(gè)元素的背景顏色匹配的背景圖像*/
.ribbon--beta .ribbon__element:nth-child(3):after {
  background-image: url(data:image/svg xml;base64,PHN2ZyBoZWlnaHQ9IjQwIiB2aWV3Qm94PSIwIDAgMTAgNDAiIHdpZHRoPSIxMCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkP SJtNSAxNSAyMCAxMGgtNDB6IiBmaWxsPSIjNGNkNGU5IiBmaWxsLXJ1bGU9ImV2ZW5vZGQiIHRyYW5zZm9ybT0ibWF0cml4KDAgLTEgLTEgMCAyNSAyNSkiLz48L3N2Zz4=);
}

就是這樣!

其餘部分與原文相似,只是對(duì)語(yǔ)句進(jìn)行了調(diào)整和替換,保持了原文意思不變。 由於篇幅限制,這裡不再贅述。 請(qǐng)參考原文繼續(xù)學(xué)習(xí)剩餘部分。

以上是哦,製作三角形麵包絲帶的許多方法!的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
CSS教程,用於創(chuàng)建加載旋轉(zhuǎn)器和動(dòng)畫 CSS教程,用於創(chuàng)建加載旋轉(zhuǎn)器和動(dòng)畫 Jul 07, 2025 am 12:07 AM

創(chuàng)建CSS加載旋轉(zhuǎn)器的方法有三種:1.使用邊框的基本旋轉(zhuǎn)器,通過(guò)HTML和CSS實(shí)現(xiàn)簡(jiǎn)單動(dòng)畫;2.使用多個(gè)點(diǎn)的自定義旋轉(zhuǎn)器,通過(guò)不同延遲時(shí)間實(shí)現(xiàn)跳動(dòng)效果;3.在按鈕中添加旋轉(zhuǎn)器,通過(guò)JavaScript切換類來(lái)顯示加載狀態(tài)。每種方法都強(qiáng)調(diào)了設(shè)計(jì)細(xì)節(jié)如顏色、大小、可訪問(wèn)性和性能優(yōu)化的重要性,以提升用戶體驗(yàn)。

解決CSS瀏覽器兼容性問(wèn)題和前綴 解決CSS瀏覽器兼容性問(wèn)題和前綴 Jul 07, 2025 am 01:44 AM

處理CSS瀏覽器兼容性和前綴問(wèn)題需理解瀏覽器支持差異並合理使用廠商前綴。 1.了解常見問(wèn)題如Flexbox、Grid支持不一,position:sticky失效,動(dòng)畫表現(xiàn)不同;2.查閱CanIuse確認(rèn)特性支持情況;3.正確使用-webkit-、-moz-、-ms-、-o-等廠商前綴;4.推薦使用Autoprefixer自動(dòng)添加前綴;5.安裝PostCSS並配置browserslist指定目標(biāo)瀏覽器;6.構(gòu)建時(shí)自動(dòng)處理兼容性;7.老項(xiàng)目可用Modernizr檢測(cè)特性;8.不必追求所有瀏覽器一致,確

顯示:內(nèi)聯(lián),顯示:塊和顯示:內(nèi)聯(lián)塊之間有什麼區(qū)別? 顯示:內(nèi)聯(lián),顯示:塊和顯示:內(nèi)聯(lián)塊之間有什麼區(qū)別? Jul 11, 2025 am 03:25 AM

Themaindifferencesbetweendisplay:inline,block,andinline-blockinHTML/CSSarelayoutbehavior,spaceusage,andstylingcontrol.1.Inlineelementsflowwithtext,don’tstartonnewlines,ignorewidth/height,andonlyapplyhorizo????ntalpadding/margins—idealforinlinetextstyling

使用CSS剪輯路徑創(chuàng)建自定義形狀 使用CSS剪輯路徑創(chuàng)建自定義形狀 Jul 09, 2025 am 01:29 AM

使用CSS的clip-path屬性可以裁剪元素為自定義形狀,如三角形、圓形缺口、多邊形等,無(wú)需依賴圖片或SVG。其優(yōu)勢(shì)包括:1.支持circle、ellipse、polygon等多種基本形狀;2.可響應(yīng)式調(diào)整,適配移動(dòng)端;3.易於動(dòng)畫化,可結(jié)合hover或JavaScript實(shí)現(xiàn)動(dòng)態(tài)效果;4.不影響佈局流,僅裁剪顯示區(qū)域。常見用法如圓形裁剪clip-path:circle(50pxatcenter)和三角形裁剪clip-path:polygon(50%0%,1000%,00%)。注意

造型與CSS不同訪問(wèn)的鏈接 造型與CSS不同訪問(wèn)的鏈接 Jul 11, 2025 am 03:26 AM

設(shè)置訪問(wèn)過(guò)鏈接的樣式能提升用戶體驗(yàn),尤其在內(nèi)容密集型網(wǎng)站中幫助用戶更好導(dǎo)航。 1.使用CSS的:visited偽類可定義已訪問(wèn)鏈接樣式,如顏色變化;2.注意瀏覽器出於隱私限制僅允許修改部分屬性;3.顏色選擇應(yīng)與整體風(fēng)格協(xié)調(diào),避免突兀;4.移動(dòng)端可能不顯示該效果,建議結(jié)合其他視覺(jué)提示如icon輔助標(biāo)識(shí)。

如何使用CSS創(chuàng)建響應(yīng)式圖像? 如何使用CSS創(chuàng)建響應(yīng)式圖像? Jul 15, 2025 am 01:10 AM

要使用CSS創(chuàng)建響應(yīng)式圖片,主要可通過(guò)以下方法實(shí)現(xiàn):1.使用max-width:100%和height:auto讓圖片在保持比例的同時(shí)自適應(yīng)容器寬度;2.結(jié)合HTML的srcset和sizes屬性智能加載適配不同屏幕的圖片源;3.利用object-fit和object-position控製圖片裁剪與焦點(diǎn)展示。這些方法共同確保圖片在不同設(shè)備上清晰、美觀地呈現(xiàn)。

什麼是常見的CSS瀏覽器不一致? 什麼是常見的CSS瀏覽器不一致? Jul 26, 2025 am 07:04 AM

不同瀏覽器對(duì)CSS解析存在差異,導(dǎo)致顯示效果不一致,主要包括默認(rèn)樣式差異、盒模型計(jì)算方式、Flexbox和Grid佈局支持程度及某些CSS屬性行為不一致。 1.默認(rèn)樣式處理不一致,解決方法是使用CSSReset或Normalize.css統(tǒng)一初始樣式;2.舊版IE的盒模型計(jì)算方式不同,建議統(tǒng)一使用box-sizing:border-box;3.Flexbox和Grid在邊緣情況或舊版本中表現(xiàn)有差異,應(yīng)多測(cè)試並使用Autoprefixer;4.某些CSS屬性行為不一致,需查閱CanIuse並提供降級(jí)

揭開CSS單元的神秘面紗:PX,EM,REM,VW,VH比較 揭開CSS單元的神秘面紗:PX,EM,REM,VW,VH比較 Jul 08, 2025 am 02:16 AM

CSS單位的選擇取決於設(shè)計(jì)需求和響應(yīng)式要求。 1.px用於固定尺寸,適合精確控制但缺乏彈性;2.em是相對(duì)單位,受父元素影響易導(dǎo)致級(jí)聯(lián)問(wèn)題,rem則基於根元素更穩(wěn)定,適合全局縮放;3.vw/vh基於視口大小,適合響應(yīng)式設(shè)計(jì),但需注意極端屏幕下的表現(xiàn);4.選擇時(shí)應(yīng)根據(jù)是否需要響應(yīng)式調(diào)整、元素層級(jí)關(guān)係及視口依賴程度來(lái)決定,合理搭配使用可提升佈局靈活性與維護(hù)性。

See all articles