vue项目的sass样式里使用data中定义的颜色

javascript 复制代码
<div :style="pageColor"></div>

 computed: {
    pageColor() {
      return {
        '--activeBgColor': 'pink',
        '--fontColor': '#fff',
        '--hoverColor': '#ff0000',
      };
    },

<style lang="scss" scoped>
::v-deep .active {
  background-color: var(--activeBgColor) !important;
  color: var(--fontColor) !important;
}

::v-deep .el-pager li:hover {
  color: var(--hoverColor) !important;
}
</style>
javascript 复制代码
// 完整代码 demo


<!--
 * @Description: 表格分页组件 页面
 * @Author: mhf
 * @Date: 2023/11/26 16:07
-->
<template>
  <el-pagination
      :style="pageColor"
      v-bind="$attrs"
      :background="background"
      :current-page.sync="currentPage"
      :page-size.sync="pageSize"
      :layout="layout"
      :page-sizes="pageSizes"
      :pager-count="pagerCount"
      :total="total"
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
  />
</template>

<script>
export default {
  name: "ytPagination",
  props: {
    total: {
      type: Number,
      default: 0,
    }, // 总条目数
    page: {
      type: Number,
      default: 1,
    },
    limit: {
      type: Number,
      default: 20,
    },
    pageSizes: {
      type: Array,
      default() {
        return [10, 20, 30, 50];
      },
    }, // 每页显示个数选择器的选项设置
    pagerCount: {
      type: Number,
      default: document.body.clientWidth < 992 ? 5 : 7,
    }, // 页码按钮的数量,当总页数超过该值时会折叠(大于等于 5 且小于等于 21 的奇数)
    layout: {
      type: String,
      default: "total, sizes, prev, pager, next, jumper",
    }, // 组件布局,子组件名用逗号分隔 (sizes, prev, pager, next, jumper, ->, total, slot)
    background: {
      type: Boolean,
      default: true,
    }, // 是否为分页按钮添加背景色
  },
  data() {
    return {};
  },
  computed: {
    pageColor() {
      return {
        '--activeBgColor': 'pink',
        '--fontColor': '#fff',
        '--hoverColor': '#ff0000',
      };
    },
    currentPage: {
      get() {
        return this.page;
      },
      set(val) {
        this.$emit("update:page", val);
      },
    },
    pageSize: {
      get() {
        return this.limit;
      },
      set(val) {
        this.$emit("update:limit", val);
      },
    },
  },
  methods: {
    handleSizeChange(val) {
      if (this.currentPage * val > this.total) {
        this.currentPage = 1;
      }
      this.$emit("pagination", {page: this.currentPage, limit: val});
    },
    handleCurrentChange(val) {
      this.$emit("pagination", {page: val, limit: this.pageSize});
    },
  },
};
</script>

<style lang="scss" scoped>
::v-deep .active {
  background-color: var(--activeBgColor) !important;
  color: var(--fontColor) !important;
}

::v-deep .el-pager li:hover {
  color: var(--hoverColor) !important;
}
</style>
相关推荐
莫物1 小时前
vue过滤表格数据导致的索引错乱问题
前端·javascript·vue.js
Можно2 小时前
Vue 组件样式隔离完全指南:从原理到实战
前端·javascript·vue.js
英俊潇洒美少年3 小时前
Vue3 完整渲染流程(从 createApp → mount → update → unmount)
前端·javascript·vue.js
前端Hardy3 小时前
Pinia 比 Vuex 好用 10 倍?Vue3 状态管理终于不折磨人了!(新手复制即用)
前端·javascript·vue.js
前端Hardy3 小时前
Vue3 的 v-model 双向绑定,90% 的人都用错了?(附 2026 最新避坑指南)
前端·javascript·vue.js
前端Hardy3 小时前
救命!Vue3 的 Composition API,居然能让我少写 80% 冗余代码?(新手也能直接抄)
前端·javascript·vue.js
王霸天4 小时前
🚨 还在用 rem) 做大屏适配?用 vfit.js 一键搞定,告别改稿8版的噩梦!
前端·vue.js·数据可视化
腾讯蓝鲸智云4 小时前
【运维自动化-节点管理】节点管理有哪些插件?如何安装插件?
运维·服务器·自动化·云计算·sass·paas
Mr Xu_4 小时前
Vue3 + Leaflet实战:深入解析MarkerCluster点位聚合插件的使用与优化
前端·javascript·vue.js
源码宝5 小时前
使用 PHP(Laravel 8)+ Vue 2 + Element UI + MySQL 5.7开发一套医院不良事件系统的注意事项
vue.js·php·laravel