如何修复 webkit (Safari) 中的光泽选择
时间:2025-01-15 18:27:26 483浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《如何修复 webkit (Safari) 中的光泽选择》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!
确保您的应用在所有浏览器引擎上都能完美运行并非易事。最近,我在DevPad项目中遇到了Safari浏览器的一个棘手问题。该项目我刻意避免使用任何UI框架或库,尽可能依赖基本的HTML元素。问题就出在一个看似普通的HTML元素——<select>
元素,它在Safari中表现异常。
对比一下,在基于Chromium的浏览器Arc中,相同的元素显示正常:
为什么Safari中的<select>
元素会呈现这种过时的、类似于2008年早期iOS的样式?其他浏览器显示正常,这究竟是怎么回事?一番搜索和尝试后,我终于找到了解决方案,但过程颇为曲折。
Stack Overflow上一个最佳答案建议使用以下CSS代码:
select {
-webkit-appearance: none;
}
但这会移除下拉箭头图标,影响用户体验,并非理想方案。
另一个答案提示使用SVG作为背景图片,但如果元素本身已经设置了背景颜色,则操作起来较为复杂。
我使用了Lucide.dev图标库,复制SVG代码并尝试应用,需要修改的是SVG的描边颜色。然而,我发现更改配色方案无法改变SVG颜色,而且CSS变量不能直接用于background-image
属性。于是我尝试使用@media
语句:
select {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background: url('data:image/svg+xml;utf8,<svg class="lucide lucide-chevron-down" fill="none" height="24" stroke="black" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" viewbox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="m6 9 6 6 6-6"></path></svg>') no-repeat;
background-size: 18px;
background-position: calc(100% - 3px) 50%;
background-repeat: no-repeat;
background-color: var(--input-background);
padding-right: 24px;
}
@media (prefers-color-scheme: dark) {
select {
background-image: url('data:image/svg+xml;utf8,<svg class="lucide lucide-chevron-down" fill="none" height="24" stroke="white" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" viewbox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="m6 9 6 6 6-6"></path></svg>') no-repeat !important;
}
}
我以为这样就能解决问题,但切换到深色模式后,箭头仍然是黑色。检查元素显示样式已应用,但出现“无效属性值”错误,尽管字符串本身没有问题(颜色错误除外)。唯一的区别是stroke="white"
代替了stroke="black"
。
这时,ChatGPT派上了用场。它巧妙地解决了这个问题:对SVG字符串进行URL编码。最终的(可运行的)CSS代码如下:
select {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background: url('data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20width=%2224%22%20height=%2224%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22black%22%20stroke-width=%222%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Cpath%20d=%22M6%209%2012%2015%2018%209%22/%3E%3C/svg%3E') no-repeat;
background-size: 18px;
background-position: calc(100% - 3px) 50%;
background-repeat: no-repeat;
background-color: var(--input-background);
padding-right: 24px;
}
@media (prefers-color-scheme: dark) {
select {
background-image: url('data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20width=%2224%22%20height=%2224%22%20viewBox=%220%200%2024%2024%22%20fill=%22none%22%20stroke=%22white%22%20stroke-width=%222%22%20stroke-linecap=%22round%22%20stroke-linejoin=%22round%22%3E%3Cpath%20d=%22M6%209%2012%2015%2018%209%22/%3E%3C/svg%3E') !important;
}
}
希望这篇文章能帮助遇到同样问题的开发者,节省大家的时间。
最终效果:完美的跨浏览器<select>
元素,支持深色/浅色模式:
如果您对DevPad项目感兴趣,请查看我的最新博客文章
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
474 收藏
-
410 收藏
-
225 收藏
-
449 收藏
-
466 收藏
-
226 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习