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>
相关推荐
花花鱼2 小时前
@antv/x6 导出图片下载,或者导出图片为base64由后端去处理。
vue.js
流烟默3 小时前
Vue中watch监听属性的一些应用总结
前端·javascript·vue.js·watch
蒲公英10014 小时前
vue3学习:axios输入城市名称查询该城市天气
前端·vue.js·学习
杨荧6 小时前
【JAVA开源】基于Vue和SpringBoot的旅游管理系统
java·vue.js·spring boot·spring cloud·开源·旅游
一 乐11 小时前
学籍管理平台|在线学籍管理平台系统|基于Springboot+VUE的在线学籍管理平台系统设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·学习
小御姐@stella12 小时前
Vue 之组件插槽Slot用法(组件间通信一种方式)
前端·javascript·vue.js
万叶学编程15 小时前
Day02-JavaScript-Vue
前端·javascript·vue.js
积水成江18 小时前
关于Generator,async 和 await的介绍
前端·javascript·vue.js
计算机学姐18 小时前
基于SpringBoot+Vue的高校运动会管理系统
java·vue.js·spring boot·后端·mysql·intellij-idea·mybatis
老华带你飞18 小时前
公寓管理系统|SprinBoot+vue夕阳红公寓管理系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·spring boot·课程设计