• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > 如何利用CSS来美化滑动输入条?自定义样式方法浅析

如何利用CSS来美化滑动输入条?自定义样式方法浅析

作者:站长图库 字体:[增加 减小] 来源:互联网 时间:2022-04-29

站长图库向大家介绍了CSS美化滑动输入条,CSS自定义样式方法等相关知识,希望对您有所帮助

如何利用CSS来美化滑动输入条(input range)?下面本篇文章给大家介绍一下利用纯 CSS 自定义滑动输入条样式的方法,希望对大家有所帮助!


如何利用CSS来美化滑动输入条?自定义样式方法浅析


关于原生 input range 滑动输入条如何自定义样式一直都是我心里的一道坎,一般情况下,可以很轻易的美化到这个程度。

如何利用CSS来美化滑动输入条?自定义样式方法浅析

为什么很容易呢?因为这些都是有对应的伪元素可以修改的

::-webkit-slider-container {  /*可以修改容器的若干样式*/}::-webkit-slider-runnable-track {  /*可以修改轨道的若干样式*/}::-webkit-slider-thumb {  /*可以修改滑块的若干样式*/}

可是,偏偏没有已滑过部分的样式,如果要定义下面这样的样式,单纯的 CSS 可能没办法实现了

如何利用CSS来美化滑动输入条?自定义样式方法浅析

注意:Firefox 有单独的伪类可以修改,本文讨论的是 Chrome 实现方案

一、我的实现思路

既然没有专门的伪元素可以修改已滑过部分的颜色,而且只有滑块是可动的,是不是可以在滑块上下手呢?

假设滑块左边有一个矩形,是跟随滑块一起的,

如何利用CSS来美化滑动输入条?自定义样式方法浅析

当这个矩形足够长时,能够完全覆盖左边的轨道,在可视范围内,是不是就可以表示左边的已滑过部分了呢?示意如下(左边半透明表示滑动条之外)

如何利用CSS来美化滑动输入条?自定义样式方法浅析

尝试过伪元素的想法,像这样

::-webkit-slider-thumb::after{  /*本想绘制一个足够长的矩形*/}

可惜,伪元素里并不能再次生成伪元素。

所以,如何在元素之外绘制一个矩形呢?


二、通过 border-image 在元素之外绘制图形

有哪些方式可以在元素之外绘制图形呢?想了一下,有 box-shadow 和 outline,但是好像并不适合这种情况,我们需要绘制的是一个尺寸可控的矩形,而这两种方式都不能很好地控制形状。那还有其他方式吗?

还真有!前两天刚看到张鑫旭老师的一篇文章:被低估的border-image属性,其中有一个特性就是在元素之外构建图像,并且不占据任何空间。赶紧试试,这里绘制一个宽度为99vw的矩形(足够覆盖滑动条就行了),代码如下

::-webkit-slider-thumb {    -webkit-appearance: none;    appearance: none;    width: 20px;    height: 20px;    border-radius: 50%;    background-color: #f44336;    border: 1px solid transparent;    margin-top: -8px;    border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0 0 0 99vw; /*绘制元素外矩形*/}

效果如下


如何利用CSS来美化滑动输入条?自定义样式方法浅析


注意几点:

border-image 要想生效,必须指定border,这里设置的是border: 1px solid transparent;

矩形是通过线性渐变绘制的 linear-gradient(#f44336,#f44336)

border-image 中8 20 8 0表示border-image-width,距离上、右、下、左的距离,由于滑块自身大小是 20 * 20,所以这个可以确定高度是 4 (20 - 8- 8),位置是滑块自身的最左边(距离右边是20)

border-image 中 0 0 0 99vw表示 border-image-outset扩展大小,这里指的是向左扩展99vw的距离

接下来通过overflow:hidden隐藏外面的部分就可以了

::-webkit-slider-container {    /*其他样式*/    overflow: hidden;}

如何利用CSS来美化滑动输入条?自定义样式方法浅析

完整代码可以访问:input range

https://codepen.io/xboxyan/pen/YzERZyE

下面附上完整代码(最近codepen貌似不太稳定)

[type="range"] {    -webkit-appearance: none;    appearance: none;    margin: 0;    outline: 0;    background-color: transparent;    width: 500px;}[type="range"]::-webkit-slider-runnable-track {    height: 4px;    background: #eee;}[type="range" i]::-webkit-slider-container {    height: 20px;    overflow: hidden;}[type="range"]::-webkit-slider-thumb {    -webkit-appearance: none;    appearance: none;    width: 20px;    height: 20px;    border-radius: 50%;    background-color: #f44336;    border: 1px solid transparent;    margin-top: -8px;    border-image: linear-gradient(#f44336,#f44336) 0 fill / 8 20 8 0 / 0px 0px 0 2000px;}


三、还是有一些局限

上面的实现成本其实是很低的,相比常规的实现基础上,仅仅增加了1行用于绘制元素之外的矩形。

如何利用CSS来美化滑动输入条?自定义样式方法浅析

如果还有好的想法欢迎留言讨论


四、简单总结一下

关于border-image-outset 这个属性,其实之前已经在 MDN 上见识过了,但只是简单了解,还觉得很鸡肋,现在看来,这些属性不是没什么用,只是没有碰到适合应用的场景。下面简单总结一下:

滑动条有 3 个伪元素可以自定义容器、轨道、滑块

伪元素里不能再嵌套伪元素了

元素之外绘制有 box-shadow、outline、border-image 3种方法

border-image 可以使用任意格式图片,包括 CSS 渐变

这个方案不能实现圆角

当然这些思路都只是“偏方”,像 Firefox 就完全支持自定义样式了,可惜桌面端还是 Chrome 的天下,只能慢慢期待一下 Chrome 后面的更新了。


分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 如何利用CSS来美化滑动输入条?自定义样式方法浅析

相关文章

  • 2022-04-29如何解决swarm docker 端口不通问题
  • 2022-04-29phpcms v9添加热门搜索关键词的方法
  • 2022-04-29Photoshop绘制时尚大气的播放界面
  • 2022-04-29PhotoShop简单制作面条艺术字体效果设计教程
  • 2022-04-29Mysql报错“Incorrect key file for table” 数据库表显示“使用中”解决办法
  • 2022-04-29踩坑分享:Laravel集成phpCAS过程
  • 2022-04-29dedecms列表页图片加ALT描述的完美方式
  • 2022-04-297B2主题美化之右上角投稿美化+加上搜索
  • 2022-04-29PS鼠绘精致开关按钮
  • 2022-04-29浅谈Bootstrap中的自适应屏幕

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • Thinkphp5如何实现图片、音频和视频文件的上传功能
    • JS数组如何删除指定元素
    • 你知道Laravel的$this->app以及app()是怎么来的吗?
    • 总结分享一些基于jQuery的前端面试(含移动端常见问题)
    • 【jquery】ajax 请求成功后新开窗口被拦截解决方法
    • Photoshop使用素材制作唯美的花体字
    • 如何解决vue中layui报错问题
    • vue中的math.sqrt的用法是什么
    • JavaScript字符串截取方法有哪些?
    • 详解ThinkPHP怎么实现图片上传

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有