vue-awesome-swiper修改分页器颜色

在vue-awesome-swiper组件API中没找到设置分页器颜色的属性,如果你找到了,欢迎在评论区留言,万分感谢!
下面说一下如何通过css自定义分页器样式:

<template>
    <swiper :class="$style.content" ref="mySwiper" :options="swiperOptions">
        <swiper-slide :class="$style.item">
            <img src="//gw.alicdn.com/imgextra/i2/98/O1CN01FAJTpN1CavPFBR5Vx_!!98-0-lubanu.jpg" alt="">
        </swiper-slide>
        <swiper-slide :class="$style.item">
            <img src="//aecpm.alicdn.com/simba/img/TB1CWf9KpXXXXbuXpXXSutbFXXX.jpg_q50.jpg" alt="">
        </swiper-slide>
        <swiper-slide :class="$style.item">
            <img src="//gw.alicdn.com/imgextra/i2/651324/O1CN015wnip71LeQyvuMH0A_!!651324-0-lubanu.jpg" alt="">
        </swiper-slide>
        <div class="swiper-pagination" slot="pagination"></div>
    </swiper>
</template>

<style lang="scss" module>
.content {
    .item {
        img {
            height: 120px;
            width: 100%;
        }
    }
}
:root {	// 这以下的代码是你需要的
    --swiper-theme-color: rgb(255, 80, 0);
}
</style>

这里需要注意的是不要用scoped去控制你的CSS作用域,不然设置样式不会生效,可以通过css module来设置作用域,需要注意的是如果你采用了这种方式,在class中引入样式需要在样式名前面加上$style.,同时class需要使用动态绑定v-bind的方式。

这里简单说一下关于scopedmodule的异同:

相同点
  1. 两者都是为了解决 CSS 类名相互干扰的问题,也就是大家常说的“作用域”问题。使用两种方案都可以达到类似效果,但是两者的区别也很明显。
不同点
  1. CSS Module 是所有组件化框架都支持的技术方案,他不属于某个框架的私有属性。而 scoped 是 Vue 框架的私有属性。
  2. CSS Module 的工作原理直白的讲就是把一个类名做 md5 ,然后在引用的时候直接使用 md5 字符串,进而保证相同的类名根据不同的路径和组件名称得到不同的 md5 值,保证了最终的类名隔离。而 scoped 的做法是做命名空间限制,也就是说每个组件就是一个命名空间,每个命名空间拥有不同的类名(md5),然后每个下面的类名都会挂在这个命名空间下进而达到隔离。
  3. 对于父组件声明的类名,在子组件内,CSS Module 是不处理的,想用必须显示调用类名($style.类名),而使用了 scoped 的因为是命名空间的方式,所以子组件依然有效。
vue-awesome-swiper中,要自定义分页,可以使用pagination组件来进行自定义。以下是一个简单的示例: ```vue <template> <div> <swiper :options="swiperOptions"> <swiper-slide v-for="(slide, index) in slides" :key="index"> <!-- 内容 --> </swiper-slide> <!-- 自定义分页 --> <div class="custom-pagination" slot="pagination"> <span v-for="(slide, index) in slides" :key="index" :class="{ active: index === activeIndex }" @click="goToSlide(index)" > {{ index + 1 }} </span> </div> </swiper> </div> </template> <script> import { swiper, swiperSlide } from "vue-awesome-swiper"; export default { components: { swiper, swiperSlide, }, data() { return { swiperOptions: { // 设置其他选项 }, slides: [ // 设置轮播项数据 ], activeIndex: 0, }; }, methods: { goToSlide(index) { this.activeIndex = index; }, }, }; </script> <style> .custom-pagination { /* 样式自定义 */ } .custom-pagination span { /* 样式自定义 */ } .custom-pagination span.active { /* 样式自定义 */ } </style> ``` 在这个示例中,我们首先导入`vue-awesome-swiper`的`swiper`和`swiperSlide`组件,然后在模板中使用`swiper`组件包裹轮播项,并设置`options`属性来配置其他选项。 接下来,在`swiper`组件内部,我们使用`slot`属性将自定义分页的内容放在名为"pagination"的插槽中。我们使用一个`v-for`循环来渲染分页中的每个页码,并在点击时调用`goToSlide`方法来切换轮播项。 最后,我们可以通过样式来自定义分页的外观,通过修改`.custom-pagination`和`.custom-pagination span`的样式来实现自定义效果。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值