CSS3 transform 字体模糊问题

使用 Vue MaterialDialog 做了一个弹出框,弹出框内动态绑定了几个数据,页面效果一出来

What the fuck? 马赛克?

Vue Material 的组件肯定没问题,应该自己代码哪问题,先把官网提供的例子在项目中运行了一下,效果正常。然后加上项目效果代码,显示一个动态数据,字体之类的都变模糊了,看来动态绑定的数据会导致 Dialog 里面的内容变模糊,显示静态内容没问题。

样式问题对于职业前端选手来说不都是分分钟搞定的事情吗?

在 Chrome-devtools 里查看一下 Dialog 元素的样式

css 复制代码
md-dialog {
    box-shadow: 0 11px 15px -7px rgba(0,0,0,.2), 0 24px 38px 3px rgba(0,0,0,.14), 0 9px 46px 8px rgba(0,0,0,.12);
    min-width: 280px;
    max-width: 80%;
    max-height: 80%;
    margin: auto;
    display: flex;
    flex-flow: column;
    flex-direction: row;
    overflow: hidden;
    position: fixed;
    top: 50%;
    left: 50%;
    z-index: 11;
    border-radius: 2px;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    pointer-events: auto;
    transform: translate(-50%,-50%);
    transform-origin: center center;
    transition: opacity .15s cubic-bezier(.25,.8,.25,1),transform .2s cubic-bezier(.25,.8,.25,1);
    will-change: opacity,transform,left,top;
}

发现 transform: translate(-50%,-50%); 这行居中css代码会导致字体模糊,直接去掉居中效果没了,继续往下看

布局图里面显示出现了小数,Dialog显示清晰的效果里面都是整数值,查看 width 属性设置,只有百分比形式,百分之五十可能 width 属性为奇数导致出现小数,添加一行 width: 280px; 试试,问题解决了。

xml 复制代码
<md-dialog  style="width: 280px;">
  <md-dialog-title></md-dialog-title>
  <md-dialog-content></md-dialog-content>
</md-dialog>

总结

使用 transform 后出现效果模糊的情况,先查看 width height 属性是否为偶数

相关推荐
王码码203510 分钟前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜15 分钟前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
天天鸭33 分钟前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
发现一只大呆瓜1 小时前
前端模块化:CommonJS、AMD、ES Module三大规范全解析
前端·面试·vite
IT_陈寒1 小时前
一文搞懂JavaScript的核心概念
前端·人工智能·后端
IT_陈寒1 小时前
Java开发者必看!5个提升开发效率的隐藏技巧,你用过几个?
前端·人工智能·后端
前端Hardy1 小时前
Wails v3 正式发布:用 Go 写桌面应用,体积仅 12MB,性能飙升 40%!
前端·javascript·go
Laurence1 小时前
Qt 前后端通信(QWebChannel Js / C++ 互操作):原理、示例、步骤解说
前端·javascript·c++·后端·交互·qwebchannel·互操作
Pu_Nine_91 小时前
JavaScript 字符串与数组核心方法详解
前端·javascript·ecmascript
码云数智-园园1 小时前
从输入 URL 到页面展示:一场精密的互联网交响乐
前端