微信小程序-灵活修改swiper组件面板指示点(indicator-dots)的内部样式

关于swiper的用法可以参考官方文档:swiper组件
本文主要介绍如何修改swiper组件的内部样式,这些通过组件属性是无法修改的。
原创文章,欢迎转载.转载请注明出处: https://www.jianshu.com/p/21899133307d

场景:

项目中可能会要求轮播图的指示点形状、间距和位置有所改变(至于颜色,可以通过属性直接修改),像下面这样:


改形状

改间距

调位置

解决方案:

有两种方式可以实现上述效果,一种是自己写组件,可以针对指示点单独写一个组件,嵌到swiper组件上(或者直接在swiper组件上扩展标签,本质都是一样的),这种方式我们不做讨论;另一种是通过修改swiper组件上的内部样式来实现,也是我们这里要介绍的。下面就具体介绍下如何解决:

小程序内部有两个类选择器负责修饰“指示点”的样式,分别是 .wx-swiper-dots.wx-swiper-dot

其中 .wx-swiper-dots 是负责面板指示点的整体样式, .wx-swiper-dot 是负责面板指示点中的一个点的样式。也就是说 .wx-swiper-dots 修饰的是父标签,.wx-swiper-dot 修饰的是子标签。

所以只需要重写 .wx-swiper-dots.wx-swiper-dot 这两个类选择器就可以灵活的修改swiper组件面板指示点的形状、间距和位置。具体解决方案如下(dot表示面板指示点中的一个点,dots表示面板指示点的整体):

  • 修改dot形状:

    /* 修改dot形状 */
    .wx-swiper-dots .wx-swiper-dot{
      width: 40rpx;    /*宽*/
      height: 10rpx;   /*高*/
      border-radius: 4rpx;  /*圆角*/
    }
    
  • 修改dot之间的间距:

    /* 修改dot之间的间距 */
    .wx-swiper-dots .wx-swiper-dot:nth-of-type(n+2) {
      margin-left: 30rpx;
    }
    
  • 调成dots的位置:

    /* 调成dots的位置 */
    /* 顶部 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      top: 40rpx;
    }
    /* 中间 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      top: 50%;
    }
    /* 右下角 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      width: 90%;
      text-align: right;
    }
    /* 左下角 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      width: 90%;
      text-align: left;
    }
    /* 左上角 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      top: 40rpx;
      width: 90%;
      text-align: left;
    }
    /* 右上角 */
    .wx-swiper-dots.wx-swiper-dots-horizontal {
      top: 40rpx;
      width: 90%;
      text-align: right;
    }
    

注意:这里调整dots位置的代码只适用于vertical属性默认为false的时候,如果vertical属性设置为true,.wx-swiper-dots-horizontal 这个选择器需要改为 .wx-swiper-dots-vertical,并且代码需要做相应修改。其实重写样式的时候 .wx-swiper-dots-horizontal 这个选择器可有可无,我这里这样写只是为了方便理解,表示上面这些代码只适用于默认情况(vertical属性为false时)。vertical为true的情况可以根据上面的代码举一反三。

vertical属性

上面这些总结参考了下面这两篇文章:
https://blog.csdn.net/qq_33030043/article/details/88077797
http://www.qianduan8.com/1009.html

具体实现:

至于如何实现,上面已做分析。下面直接贴出写好的demo源码和实现效果以及demo下载链接:

home.wxml:

<!--pages/home/home.wxml-->
<view class='title'>修改dot之间的间距:</view>
<view class='spacing'>
  <swiper 
    indicator-dots="{{true}}"
    autoplay="{{true}}" 
    interval="{{3000}}" 
    duration="{{500}}"
    circular="{{true}}"
    indicator-active-color="#28A5F6"
    style="height:{{400}}rpx;">
    <block wx:for="{{imgUrls}}" wx:key="{{key}}">
      <swiper-item>
        <image src="{{item}}"/>
      </swiper-item>
    </block>
  </swiper>
</view>

<view class='title'>修改dot的形状:</view>
<view class='shape'>
  <swiper 
    indicator-dots="{{true}}"
    autoplay="{{true}}"
    interval="{{3000}}"
    duration="{{500}}"
    circular="{{true}}"
    indicator-active-color="#28A5F6"
    style="height:{{400}}rpx;">
    <block wx:for="{{imgUrls}}" wx:key="{{key}}">
      <swiper-item>
        <image src="{{item}}"/>
      </swiper-item>
    </block>
  </swiper>
</view>

<view class='title'>调整dots的位置:</view>
<view class='location'>
  <swiper 
    indicator-dots="{{true}}"
    autoplay="{{true}}" 
    interval="{{3000}}" 
    duration="{{500}}"
    circular="{{true}}"
    indicator-active-color="#28A5F6"
    style="height:{{400}}rpx;">
    <block wx:for="{{imgUrls}}" wx:key="{{key}}">
      <swiper-item>
        <image src="{{item}}"/>
      </swiper-item>
    </block>
  </swiper>
</view>

home.wxss:

.spacing swiper-item image, .shape swiper-item image, .location swiper-item image {
  width: 750rpx;
  height: 400rpx;
}
/* 修改dot之间的间距 */
.spacing .wx-swiper-dots .wx-swiper-dot:nth-of-type(n+2) {
  margin-left: 30rpx;
}

/* 修改dot形状 */
.shape .wx-swiper-dots .wx-swiper-dot{
  width: 40rpx;    /*宽*/
  height: 10rpx;   /*高*/
  border-radius: 4rpx;  /*圆角*/
}

/* 调成dots的位置 */
/* 顶部 */
/* .location .wx-swiper-dots.wx-swiper-dots-horizontal {
  top: 40rpx;
} */
/* 中间 */
/* .location .wx-swiper-dots.wx-swiper-dots-horizontal {
  top: 50%;
} */
/* 右下角 */
.location .wx-swiper-dots.wx-swiper-dots-horizontal {
  width: 90%;
  text-align: right;
}
/* 左下角 */
/* .location .wx-swiper-dots.wx-swiper-dots-horizontal {
  width: 90%;
  text-align: left;
} */
/* 左上角 */
/* .location .wx-swiper-dots.wx-swiper-dots-horizontal {
  top: 40rpx;
  width: 90%;
  text-align: left;
} */
/* 右上角 */
/* .location .wx-swiper-dots.wx-swiper-dots-horizontal {
  top: 40rpx;
  width: 90%;
  text-align: right;
} */

home.js:

// pages/home/home.js
Page({

  /**
   * 页面的初始数据
   */
  data: {
    imgUrls: [
      '../../static/images/banner1.jpg',
      '../../static/images/banner2.jpg',
      '../../static/images/banner3.jpg',
      '../../static/images/banner4.jpg',
      '../../static/images/banner5.jpg'
    ],
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad: function (options) {

  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady: function () {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow: function () {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide: function () {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload: function () {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {

  }
})

home.json:

{
  "usingComponents": {},
  "navigationBarTitleText": "首页"
}

实现效果:

实现效果

demo下载链接:

https://github.com/w-wh/wx-indicator-dots-demo

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342