自定义el-slider 滑块的样式

最近用到了element组件中的滑块,翻看了官网和网上一些案例,感觉和我要的样式都不太一样,下面记录一下我用到的两种自定义滑块。

效果图

第一种自定义画过的间断点样式

起始样式

滑动的样式

第二种自定义拖动滑块的样式

起始样式

滑动的样式

自定义画过的间断点样式的实现

javascript 复制代码
<template>
   <div class="d-flex align-items-start">
        <div class="search-item-label" style="line-height: 38px;">公网带宽</div>
        <div class="d-flex align-items-center">
          <el-slider
                class="ml-1 mr-4"
                :class="{'activeSlider0' : state.netBrandWidth > 0,'activeSlider1' : state.netBrandWidth > 50, 'activeSlider2' : state.netBrandWidth > 100, 'activeSlider3' : state.netBrandWidth > 150, 'activeSlider4' : state.netBrandWidth > 200}" // 滑动到不同位置时添加不同的classname,来定义滑动过后的样式
                v-model="state.netBrandWidth"
                :min="0"
                :max="200"
                :marks="netBrandWidthMarks"  // 标记
                :format-tooltip="netBrandWidthFormatterTooltip" // 滑动快hover时上方显示文字
                style="width: 416px">
          </el-slider>
     </div>
   </div>
</template>
<script setup>
import { reactive, ref } from 'vue'
const state = reactive({
  netBrandWidth: 1
})
const netBrandWidthMarks = ref({ // 标记
  0: '0M',
  50: '50M',
  100: '100M',
  150: '150M',
  200: '200M'
})
// 公网带宽
const netBrandWidthFormatterTooltip = (value) => { // 滑动快hover时上方显示文字
  return value > 0 ? `${ value }Mbps` : '无公网'
}
</script>
<style scoped lang="scss">
.el-slider__runway{ // 滑块的进度条颜色
  background-color: #F2F3F7;
}
.el-slider__stop { // 进度条上间断点的样式
  width: 10px;
  height: 10px;
  top: -2px;
  background: #FFFFFF;
  border: 1px dotted #4C66CE;
  box-sizing: border-box;
}

.el-slider__button { // 拖动的滑块的样式
  width: 16px;
  height: 16px;
  background-color: #FFFFFF;
  box-shadow: 0px 0px 4px 0px rgba(64,83,159,0.73);
  border: 3px solid #4C66CE;
}
.el-slider__marks-text{ // 底部标记的样式
  font-size: 12px;
  color: #999999;
}
.activeSlider0 .el-slider__runway{ // 滑动到不同位置时添加不同的classname,来定义滑动过后的样式
  .el-slider__stop:first-child{ // 间断点样式
    background-color: #4C66CE;
  }
}
.activeSlider1 .el-slider__runway{
  .el-slider__stop:first-child,.el-slider__stop:nth-child(2){
    background-color: #4C66CE;
  }
}
.activeSlider2 .el-slider__runway{
  .el-slider__stop:first-child,.el-slider__stop:nth-child(2),.el-slider__stop:nth-child(3){
    background-color: #4C66CE;
  }
}
.activeSlider3 .el-slider__runway{
  .el-slider__stop:first-child,.el-slider__stop:nth-child(2),.el-slider__stop:nth-child(3),.el-slider__stop:nth-child(4){
    background-color: #4C66CE;
  }
}
.activeSlider4 .el-slider__runway{
  .el-slider__stop:first-child,.el-slider__stop:nth-child(2),.el-slider__stop:nth-child(3),.el-slider__stop:nth-child(4),.el-slider__stop:nth-child(5){
    background-color: #4C66CE;
  }
}
</style>

自定义拖动滑块样式的实现

javascript 复制代码
<template>
   <div class="d-flex align-items-start">
        <div class="search-item-label" style="line-height: 38px;">公网带宽</div>
        <div class="d-flex align-items-center">
          <el-slider
                class="ml-1 mr-4"
                v-model="state.netBrandWidth"
                :min="0"
                :max="200"
                :marks="netBrandWidthMarks"  // 标记
                :format-tooltip="netBrandWidthFormatterTooltip" // 滑动快hover时上方显示文字
                style="width: 416px">
          </el-slider>
     </div>
   </div>
</template>
<script setup>
import { reactive, ref } from 'vue'
const state = reactive({
  netBrandWidth: 1
})
const netBrandWidthMarks = ref({ // 标记
  0: '0M',
  50: '50M',
  100: '100M',
  150: '150M',
  200: '200M'
})
// 公网带宽
const netBrandWidthFormatterTooltip = (value) => { // 滑动快hover时上方显示文字
  return value > 0 ? `${ value }Mbps` : '无公网'
}
</script>
<style scoped lang="scss">
.el-slider__stop { // 进度条上间断点的样式
  border: 1px solid var(--el-color-primary);
  box-sizing: border-box;
}

.el-slider__button { // 拖动的滑块的样式
  width: 16px;
  height: 22px;
  border: 1px solid var(--el-color-primary);
  border-radius: 1px;
  position: relative;
  left: 4px;
}

.el-slider__button:before { 
  content: '';
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 3px;
  height: 6px;
  background: transparent;
  box-shadow: -3px 0 0 -1px var(--el-color-primary), 3px 0 0 -1px var(--el-color-primary);
}

.el-slider__button:after {
  content: '';
  display: block;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 7px;
  background: var(--el-color-primary);
  z-index: 999;
}
</style>
相关推荐
ejinxian1 小时前
Rust GUI框架Azul与Electron、WebView2
前端·javascript·electron
IT_陈寒2 小时前
Vue的v-for里用index当key,我被自己坑惨了
前端·人工智能·后端
军军君012 小时前
数字孪生监控大屏实战模板:智能业务大数据监管平台
css·vue.js·elementui·typescript·前端框架·echarts·less
代码不加糖2 小时前
0基础搭建前后端分离项目:实现菜单与界面左右布局
java·前端·javascript·mysql·elementui·mybatis
zhensherlock3 小时前
Protocol Launcher 系列:Tally 快速计数器的深度集成
前端·javascript·typescript·node.js·自动化·github·js
AC赳赳老秦3 小时前
OpenClaw权限管理实操:团队共享Agent,设置操作权限,保障数据安全
服务器·开发语言·前端·javascript·excel·deepseek·openclaw
光影少年3 小时前
Polyline 组件如何绘制渐变区域?
前端·javascript·掘金·金石计划
Pkmer3 小时前
古法编程: React思维模型快速建立
前端·react.js
普通网友3 小时前
JavaScript:ESLint+Prettier 规范代码格式
开发语言·javascript·ecmascript
jiayong233 小时前
第 38 课:任务列表里高亮当前正在查看详情的任务
开发语言·前端·javascript·vue.js·学习