background-clip 组合拳的一个小玩法_html/css_WEB-ITnose
之前项目里有个半透明的Tag组件如下,长度随字数自增,箭头可左可右。
开始用代码实现,分拆为【圆角矩形+圆角三角】2个元素组合实现,但总是无法完美实现,原因至少有:
- 半透明特性,若有重合区域会透明度叠加重影。
- 两元素的高度定位总无法匹配一致(viewport缩放导致)。
多次折腾后摸索出一个方法,使用小图片,组合多个 CSS3的background子属性 ,只用一个元素实现效果:
padding-right: 18px; background-image: url(https://img.alicdn.com/tps/TB1t0O9IFXXXXb8XXXXXXXXXXXX.png), url(https://img.alicdn.com/tps/TB1hNC6IFXXXXaEXpXXXXXXXXXX.png); background-position: right 0; background-size: contain; background-repeat: no-repeat, repeat-x; background-clip: padding-box, content-box;
- 首先利用CSS3的多重背景图特性,为一个元素插2张图(图片都很小)。
- 再使用 background-clip 的特性,将2张背景图片附着于元素的不同区域,这个特性类似box-sizing的设置。
- 顺带的,这里可以结合 background-origin 理解下,两种属性的值选项范围相同,但概念有差别,所以实现的效果不同。
- clip是裁剪,origin是起点。前者会破坏背景图完整度,后者只改变背景图出现的起点区域。具体定义 可戳这里 。
- 之后结合双重赋值的 background-position 和 background-repeat 属性,为pading和content区域的背景图片进行差异化设置。
- 注意这里的repeat,矩形主体部分因为是repeat-x刷出的,所以代码里使用了 background-clip 而不是 background-origin ,后者在这里的效果被 background-repeat 低效。再次体现了CSS调试里常见的 交叉干扰 现象
- 这样就可以达成一个 单元素长度自适应Tag 。
最终元素布局审查如图

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

HTML is suitable for beginners because it is simple and easy to learn and can quickly see results. 1) The learning curve of HTML is smooth and easy to get started. 2) Just master the basic tags to start creating web pages. 3) High flexibility and can be used in combination with CSS and JavaScript. 4) Rich learning resources and modern tools support the learning process.

HTML defines the web structure, CSS is responsible for style and layout, and JavaScript gives dynamic interaction. The three perform their duties in web development and jointly build a colorful website.

WebdevelopmentreliesonHTML,CSS,andJavaScript:1)HTMLstructurescontent,2)CSSstylesit,and3)JavaScriptaddsinteractivity,formingthebasisofmodernwebexperiences.

AnexampleofastartingtaginHTMLis,whichbeginsaparagraph.StartingtagsareessentialinHTMLastheyinitiateelements,definetheirtypes,andarecrucialforstructuringwebpagesandconstructingtheDOM.

GiteePages static website deployment failed: 404 error troubleshooting and resolution when using Gitee...

The Y-axis position adaptive algorithm for web annotation function This article will explore how to implement annotation functions similar to Word documents, especially how to deal with the interval between annotations...

HTML, CSS and JavaScript are the three pillars of web development. 1. HTML defines the web page structure and uses tags such as, etc. 2. CSS controls the web page style, using selectors and attributes such as color, font-size, etc. 3. JavaScript realizes dynamic effects and interaction, through event monitoring and DOM operations.

To achieve the effect of scattering and enlarging the surrounding images after clicking on the image, many web designs need to achieve an interactive effect: click on a certain image to make the surrounding...
