css 同时实现渐变色和文字阴影

今天在工作中根据UI实现标题文字的样式,却发现拷贝的相关css却怎么都实现不了。

ui图如下:

实现渐变的方法

实现渐变的方法其实很简单,主要是用背景的渐变来实现的,先将字体的颜色变成透明,然后设置背景为渐变色就可以了

渐变效果如下:

然后叠加字体的阴影,直接添加text-shadow属性,可是效果却不是我们想要的,发现阴影覆盖在了字体之上

解决办法

利用::before伪类的帮助,将字体的阴影加在伪类之上。

问题1: ts报错: 可是伪类的content需要设置文字切不能写死怎么办呢?解决办法就是在<div>中添加属性,可是随便添加的data属性,ts会直接报错,后来我查询了基本的html标签之后才知道,默认有一个title属性是符合要求的,于是就将title属性传递文字信息,完美解决了我的问题。

问题2:层级问题不显示,我发现就算伪类设置了z-index: -1;并且为绝对定位了,但是效果还是没有显示,我继续往上找父类,原来需要将背景图上的divz-index设置为0才可以,至此,终于实现了我想要的效果。如果没有背景图应该就不需要设置了。

完整代码

html 复制代码
   const title = "渐变色和文字阴影"
  <div className={styles.bg}>
      <div className={styles.title} title={title}>
        {title}
      </div>
    </div>
css 复制代码
.bg {
  url('https://pic.616pic.com/bg_w1180/00/03/63/c46SCIz9QV.jpg');
  background-size: 100% 100%;
  width: 498px;
  height: 57px;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 0;
  

  .title {
    background: linear-gradient(177deg, #FFF 40.11%, #6CA7ED 78.94%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-family: PangMenZhengDao-3;
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
  }

  .title::before {
    content:attr(title);
    position: absolute;
    z-index: -1;
    text-shadow: 0px 4px 3px rgba(4, 50, 140, 0.81), 0px 0px 13px rgba(89, 105, 252, 0.60);
  }
}
相关推荐
张一凡9315 小时前
React 项目也能用依赖注入?我尝试了一下,真香
前端·react.js
somebody15 小时前
零经验学 react 的第15天 - 过渡动画(使用 react-transition-group 库进行实现)
前端
SuperEugene16 小时前
Vue3 + Element Plus 表单开发实战:防重复提交、校验、重置、loading 统一|表单与表格规范篇
前端·javascript·vue.js
SuperEugene16 小时前
Vue3 + Element Plus 中后台弹窗规范:开闭、传参、回调,告别弹窗地狱|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
桜吹雪16 小时前
在前端运行Qwen3.5原生多模态模型
前端·人工智能·机器学习
孟祥_成都16 小时前
前端下午茶:这 3 个网页特效建议收藏(送源码)
前端·javascript·css
SuperEugene16 小时前
VXE-Table 4.x 实战规范:列配置 + 合并单元格 + 虚拟滚动,避坑卡顿 / 错乱 / 合并失效|表单与表格规范篇
开发语言·前端·javascript·vue.js·前端框架·vxetable
火车叼位16 小时前
Volta 下 `corepack` 失踪之谜:问题不在 Node,而在命令入口
前端
cmd16 小时前
别再用错!5种JS类型判断方法,从原理到实战一文吃透
前端·javascript
小江的记录本16 小时前
【Redis】Redis常用命令速查表(完整版)
java·前端·数据库·redis·后端·spring·缓存