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>
相关推荐
paopaokaka_luck11 分钟前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序
一大树33 分钟前
Vue3祖孙组件通信方法总结
前端·vue.js
coder_zhx39 分钟前
Vue3自定义编程式弹窗
前端·vue.js
独立开阀者_FwtCoder1 小时前
面试官:为什么在 Vue3 中 ref 变量要用 .value?
前端·javascript·vue.js
NetX行者1 小时前
基于Vue 3的AI前端框架汇总及工具对比表
前端·vue.js·人工智能·前端框架·开源
独立开阀者_FwtCoder1 小时前
手握两大前端框架,Vercel 再出手拿下 Nuxt.js,对前端有什么影响?
前端·javascript·vue.js
独立开阀者_FwtCoder1 小时前
弃用 html2canvas!快 93 倍的截图神器!
前端·javascript·vue.js
rui锐rui2 小时前
商品销售数据分析实验
vue.js·数据挖掘·数据分析
Bruce_Json2 小时前
微信小程序ts+sassjlin-ui
微信小程序·小程序·sass
洛小豆2 小时前
深入理解Pinia:Options API vs Composition API两种Store定义方式完全指南
前端·javascript·vue.js