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>
相关推荐
让我上个超影吧17 分钟前
基于SpringBoot和Vue实现CAS单点登录
前端·vue.js·spring boot
gg159357284602 小时前
JavaScript 核心基础
前端·javascript·vue.js
北辰alk2 小时前
从零设计一个Vue路由系统:揭秘SPA导航的核心原理
前端·vue.js
计算机毕设VX:Fegn08953 小时前
计算机毕业设计|基于springboot + vue个人博客系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
幽络源小助理3 小时前
SpringBoot+Vue美食网站系统源码 | Java餐饮项目免费下载 – 幽络源
java·vue.js·spring boot
这是个栗子3 小时前
【Vue代码分析】vue方法的调用与命名问题
前端·javascript·vue.js·this
全栈前端老曹4 小时前
【前端路由】Vue Router 动态导入与懒加载 - 使用 () => import(‘...‘) 实现按需加载组件
前端·javascript·vue.js·性能优化·spa·vue-router·懒加载
北辰alk4 小时前
Vue 3 深度解析:watch 与 watchEffect 的终极对决
vue.js
LYFlied4 小时前
Vue.js 中的 XSS 攻击防护机制详解
前端·vue.js·xss
xu_duo_i5 小时前
vue3+element-plus图片上传,前端压缩(纯函数,无插件)
前端·javascript·vue.js