支付宝小程序Swiper 滚动图 带圆点和跳转方式

支付宝小程序Swiper 滚动图 带圆点和跳转方式,第1张

```

<!-- 滚动图 -->

<view class="swiper" style="position:relative">

<swiper autoplay="{{true}}" circular="{{true}}" onChange="currentHandle">

        <block a:for="{{swiperList}}">

          <swiper-item class="swiper-box">

            <view class="swiper-item" style="width:100%height:300rpx">

                <!-- lazy-load根据需要 onTap可以点击图片跳转 data-url绑定到跳转的链接-->

              <image lazy-load="{{true}}" mode="scaleToFill" src="{{item.image}}" style="display:flexwidth:100%height:300rpx"

                onTap="swiper" data-url="{{item.url}}" data-index='{{index}}' />

            </view>

          </swiper-item>

        </block>

      </swiper>

    <!-- 圆点 -->

      <view class="swiper_dot">

        <view class="trans MR10 {{current === index ?'active': ''}}" a:for="{{swiperList}}" a:key="{{index}}"></view>

      </view>

</view>

```

```

data(){

    swiperList:[

        {

            image:'',//图片的路径

            url:""//要跳转的路径

        },

                {

            image:'',

            url:""

        }

    ],

    current: 0,//初始化dot

},

//监听current

currentHandle(e) {

console.log(e)

    //改变current的值

    let { current } = e.detail

    this.setData({

      current

    })

},

```

```

.swiper-box {

  padding: 0 30rpx

}

.swiper-item {

  border-radius: 10rpx

  overflow: hidden

}

.swiper_dot {

  display: flex

  flex: 1

  justify-content: center

  position: absolute

  bottom: 16rpx

  left: 42%//通过绝对定位 在滚动图的正下方 具体看自己

}

.MR10 {

  margin-right: 10rpx

}

.trans {

  width: 23rpx

  height: 8rpx

  background-color: #ffffff70

  border-radius: 3.5rpx

  transition: width 0.5s linear

}

.active {

  background-color: #ffffffd7

  width: 67rpx

  transition: width 0.5s linear

}

```

---转自我的自个的

支付宝小程序Swiper 滚动图 带圆点和跳转方式_多甘范科夫斯基的博客-CSDN博客

从前端转小程序开发的成本几乎可以忽略不计,上手前只需要注意一些地方即可。

小程序的界面是一个「应用界面」,而非「网页」,需适应WXML的逻辑和写法。

WXML没有HTML的宽容度那么高,单标签必需是 />结尾的,不然会报错。

WXSS 和 CSS很像,基本上所有的CSS都支持,小程序还提供了rpx (responsive pixel)作为尺寸单位(保证不同分辨率设备的元素正常显示),开发者需知道rpx与其他单位的换算。

WXSS不支持大括号嵌套({{}}),所以key-frames,CSS animation 不能用,但transition 可用的。

当然,这种限制也会催生一种东西:专用于小程序的开发框架。

往左边滑动出现删除按钮, 只对当前滑动的对象 *** 作

<view class="shop-list">

    <view class="check-all-box" bindtap="onCheckAll">

      <view>

        <label class="check-around8"  bindtap="selected" data-lor='1'>

          <radio checked="{{allSelected?true:false}}" color="#000"></radio>

          <text class="check-all">{{checkAllText}}全选</text>

        </label> 

      </view>

    </view>

    <view class="item-box  {{item.isTouchMove ? 'touch-move-active' : ''}}" data-index="{{index}}" bindtouchstart="touchstart" bindtouchmove="touchmove" wx:for="{{list}}" wx:key="{{index}}">

      <view class="item">

        <view class="check-around-box" data-id="{{item.id}}" >

            <label bindtap="selected" data-id="{{item.id}}" data-isSelect="{{item.isSelect}}">

              <radio checked="{{item.isSelect>0?true:false}}" color="#000"></radio>

            </label>   

          </view>

        <view class="item-img-box">

          <image class="item-img" src="{{item.thumbUrl}}" />

        </view>

        <view class="item-info-box">

          <text class="item-title">{{item.title}}</text>

          <text class="item-spec">{{item.spec}}</text>

          <text class="item-price">¥{{item.price}}</text>

          <view class="num-box">

            <view class="num-desc" data-id="{{item.id}}" data-total="{{item.total}}" bindtap="reduce">-</view>

            <input class="item-input" type="number"disabled="boolean" value="{{item.total}}" />

            <view class="num-plus" data-id="{{item.id}}" data-total="{{item.total}}" bindtap="plus">+</view>

          </view>

        </view>

      </view>

      <view class="remove" data-id="{{item.id}}" bindtap="remove">{{remove}}删除</view>

    </view>

  </view>

page{

  background-color: #f8f8f8

}

.shop-list {

  display: flex

  flex-direction: column

  margin-top: 30rpx

  padding-bottom:120rpx

}

.check-all-box {

  display: flex

  align-items: center

  padding: 30rpx

  background-color: #fff

}

.check-all-box  .check-all {

  margin-left: 20rpx

  font-size: 30rpx

}

.check-around {

  width: 35rpx

  height: 35rpx

  margin-right:20rpx

  border-radius: 50rpx

  border: 1rpx solid #f8f8f8

}

.check-active {

  width: 35rpx

  height: 35rpx

  border-radius: 50rpx

  background-color: #999999

}

.item-box {

  margin-bottom: 20rpx

  position: relative

  z-index: 99

  font-size: 14px

  display: flex

  justify-content: space-between

  border-bottom:1px solid #ccc

  width: 100%

  overflow: hidden

}

.item {

  display: flex

  align-items: center

  padding: 30rpx

  background-color: #fff

  position: relative

  z-index: 99

  width: 100%

  margin-right:0

  -webkit-transition: all 0.4s

  transition: all 0.4s

  -webkit-transform: translateX(90px)

  transform: translateX(90px)

  margin-left: -90px

}

.item .item-img {

  width: 180rpx

  height: 180rpx

  border-radius: 5rpx

  border: 1rpx solid #eaeaea

}

.item .item-info-box {

  display: flex

  flex-direction: column

  justify-content: space-between

  width: 420rpx

  height: 180rpx

  margin-left:20rpx

}

.item-info-box .item-title {

  font-size: 30rpx

  white-space: nowrap

  text-overflow: ellipsis

  overflow: hidden

  word-break: break-all

}

.item-info-box .item-spec {

  color: #676767

  margin-top: 15rpx

  text-overflow: -o-ellipsis-lastline

  overflow: hidden

  text-overflow: ellipsis

  display: -webkit-box

  -webkit-line-clamp: 2

  line-clamp: 2

  -webkit-box-orient: vertical

}

.item-info-box .item-price {

  display: flex

  margin-top: 15rpx

}

.item-info-box .num-box {

  display: flex

  align-items: center

  justify-content: flex-end

  font-size: 30rpx

}

.num-box .num-desc {

  padding: 0 10rpx

  color: #999

  border: 4rpx solid #999

}

.num-box .item-input {

  width: 80rpx

}

.item-input {

  text-align: center

}

.num-box .num-plus {

  padding: 0 10rpx

  color: #fff

  background-color: #000

  border: 4rpx solid #000

}

.remove {

  background-color: orangered

  width: 90px

  display: flex

  flex-direction: column

  align-items: center

  justify-content: center

  color: #fff

  -webkit-transform: translateX(90px)

  transform: translateX(90px)

  -webkit-transition: all 0.4s

  transition: all 0.4s

}

.touch-move-active .item,

.touch-move-active .remove {

  -webkit-transform: translateX(0)

  transform: translateX(0)

}

var app = getApp()

Page({

  data: {

    list: [

      {

        id: '1',

        thumbUrl: 'https://cdnimg.pfhoo.com/Pro/s/20180404/8a22565d-9bb3-4b87-bf58-00e9db0e2d28.jpg',

        title: '大英博物馆珠宝首饰系列“OK”首饰',

        spec: 'K黄',

        price: '199.10',

        num: 1,

        total: 10

      }, {

        id: '2',

        thumbUrl: 'https://cdnimg.pfhoo.com/Pro/s/20180404/8a22565d-9bb3-4b87-bf58-00e9db0e2d28.jpg',

        title: '大英博物馆珠宝首饰系列“OK”首饰',

        spec: 'K黄',

        price: '899.20',

        num: 1,

        total: 1

      }

    ],

    startX: 0, //开始坐标

    startY: 0

  },

  onLoad: function () {

  },

  //手指触摸动作开始 记录起点X坐标

  touchstart: function (e) {

    //开始触摸时 重置所有删除

    this.data.list.forEach(function (v, i) {

      if (v.isTouchMove)//只 *** 作为true的

        v.isTouchMove = false

    })

    this.setData({

      startX: e.changedTouches[0].clientX,

      startY: e.changedTouches[0].clientY,

      list: this.data.list

    })

  },

  //滑动事件处理

  touchmove: function (e) {

    var that = this,

      index = e.currentTarget.dataset.index,//当前索引

      startX = that.data.startX,//开始X坐标

      startY = that.data.startY,//开始Y坐标

      touchMoveX = e.changedTouches[0].clientX,//滑动变化坐标

      touchMoveY = e.changedTouches[0].clientY,//滑动变化坐标

      //获取滑动角度

      angle = that.angle({ X: startX, Y: startY }, { X: touchMoveX, Y: touchMoveY })

    that.data.list.forEach(function (v, i) {

      v.isTouchMove = false

      //滑动超过30度角 return

      if (Math.abs(angle) >30) return

      if (i == index) {

        if (touchMoveX >startX) //右滑

          v.isTouchMove = false

        else //左滑

          v.isTouchMove = true

      }

    })

    //更新数据

    that.setData({

      list: that.data.list

    })

  },

  /**

  * 计算滑动角度

  * @param {Object} start 起点坐标

  * @param {Object} end 终点坐标

  */

  angle: function (start, end) {

    var _X = end.X - start.X,

      _Y = end.Y - start.Y

    //返回角度 /Math.atan()返回数字的反正切值

    return 360 * Math.atan(_Y / _X) / (2 * Math.PI)

  },

  //删除事件

  remove: function (e) {

    let that =this

    let index = e.currentTarget.dataset.index

    let list = that.data.list

    wx.showModal({

      title: 'w温馨提示!',

      content: '你确认删除吗?',

      success: function (res) {

        if (res.confirm) {

          console.log('444')

          list.splice(index, 1)

          that.setData({

            list:list

          })

        } else{

          console.log('用户点击取消')

        }

      }

    })

  }

})


欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/yw/11567872.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存