那些复杂的颜色实现

渐变边框颜色

设计大大的精妙稿子,怎么能不去实现呢(🤷摊手.png)!

之前合作的设计师,给的一个视觉稿子效果图,里面有个解锁区域的边框渐变效果,大致如下图所示。 边框是一个透明度从0%->100%->0%->83%->6%的渐变效果再叠加了一个外发光,实现难点主要实现一个渐变边框线。

实现思路:

div层添加圆角度,后续通过伪元素,添加一个特殊(transparent->red->transparent->red->transparent)渐变的mask层。

核心代码:

js 复制代码
<div class="con">哈哈哈</div>
// css
.con {
  min-height: 130px;
  position: relative;
  border-radius: 8px;
}
.con:before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  border: 0.01rem solid #dbc091;
  border-radius: inherit;
  -webkit-mask: lineargradient(to right bottom,transparent,red,transparent,red,transparent);
}

动态渐变背景色

css 复制代码
background: linear-gradient(106deg, rgba(77, 176, 0, 0.16) 0%, rgba(77, 176, 0, 0.08) 100%);

涉及到实际的业务动态下发的需求场景,它的实现需要再斟酌一下。

业务场景:接口下发一个纯色颜色值(rgb或者hex都有可能)效果展示上需要实现背景色为指定颜色colorA的一个渐变从透明度16%到8%。

方案一:纯色背景上叠加白色透明渐变(无黑夜模式适配首选)

具体思路如下所示,在色块上方叠加一个白色固定透明度即可

核心代码:

css 复制代码
background: linear-gradient(to right bottom, rgba(255,255,255, .84), rgba(255,255,255, .92)), #4DB000;

完整代码:

html 复制代码
// dom
<div class="card" style="--color: red">哈哈哈</div>
// css
.card {
  background: linear-gradient(to right bottom, rgba(255,255,255, .84), rgba(255,255,255, .92)), var(--color);
  min-height: 130px;
}

缺点: 无法适配黑夜模式or透过显示部分底层元素

方案二:纯色背景+mask

具体思路如下所示,在背景色块上添加一个任意颜色(此次为了简写用的#000)渐变mask即可。

核心代码:

css 复制代码
background: #4DB000;
-webkit-mask: linear-gradient(to right bottom, rgba(0,0,0,.86), rgba(0,0,0,.08))

完整代码:

less 复制代码
// dom
<div class="card" style="--color: red">哈哈哈</div>
// css
.card {
  position: relative;
  min-height: 130px;
}
.card::before{
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background: var(--color);
  -webkit-mask: linear-gradient(to right bottom, rgba(0,0,0,.86), rgba(0,0,0,.08))
}

body {
  background: url('./img.jpg')
}

效果图

(PS:此处为看效果,左上方的Alpha由0.16改成0.46了) 兼容性: -webkit-mask兼容性好像还好~,移动端应该可以使用的~~~

参考文档:

相关推荐
新中地GIS开发老师37 分钟前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang44 分钟前
前端性能优化
前端·javascript·vue.js·性能优化
Rysxt_1 小时前
Element Plus 入门教程:从零开始构建 Vue 3 界面
前端·javascript·vue.js
隐含1 小时前
对于el-table中自定义表头中添加el-popover会弹出两个的解决方案,分别针对固定列和非固定列来隐藏最后一个浮框。
前端·javascript·vue.js
大鱼前端1 小时前
Turbopack vs Webpack vs Vite:前端构建工具三分天下,谁将胜出?
前端·webpack·turbopack
你的人类朋友1 小时前
先用js快速开发,后续引入ts是否是一个好的实践?
前端·javascript·后端
知识分享小能手1 小时前
微信小程序入门学习教程,从入门到精通,微信小程序核心 API 详解与案例(13)
前端·javascript·学习·react.js·微信小程序·小程序·vue
子兮曰2 小时前
npm workspace 深度解析:与 pnpm workspace 和 Lerna 的全面对比
前端·javascript·npm
颜酱2 小时前
用搬家公司的例子来入门webpack
前端·javascript·webpack