background-clip 组合拳的一个小玩法_html/css_WEB-ITnose

php中文网
发布: 2016-06-24 11:21:32
原创
1520人浏览过

之前项目里有个半透明的tag组件如下,长度随字数自增,箭头可左可右。

开始用代码实现,分拆为【圆角矩形+圆角三角】2个元素组合实现,但总是无法完美实现,原因至少有:

  1. 半透明特性,若有重合区域会透明度叠加重影。
  2. 两元素的高度定位总无法匹配一致(viewport缩放导致)。

多次折腾后摸索出一个方法,使用小图片,组合多个 CSS3的background子属性 ,只用一个元素实现效果:

法语写作助手
法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

法语写作助手 31
查看详情 法语写作助手

  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; 
登录后复制

立即学习前端免费学习笔记(深入)”;

  1. 首先利用CSS3的多重背景图特性,为一个元素插2张图(图片都很小)。
  2. 再使用 background-clip 的特性,将2张背景图片附着于元素的不同区域,这个特性类似box-sizing的设置。
    1. 顺带的,这里可以结合 background-origin 理解下,两种属性的值选项范围相同,但概念有差别,所以实现的效果不同。
    2. clip是裁剪,origin是起点。前者会破坏背景图完整度,后者只改变背景图出现的起点区域。具体定义 可戳这里 。
  3. 之后结合双重赋值的 background-position 和 background-repeat 属性,为pading和content区域的背景图片进行差异化设置。
    1. 注意这里的repeat,矩形主体部分因为是repeat-x刷出的,所以代码里使用了 background-clip 而不是 background-origin ,后者在这里的效果被 background-repeat 低效。再次体现了CSS调试里常见的 交叉干扰 现象
  4. 这样就可以达成一个 单元素长度自适应Tag

最终元素布局审查如图

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号