美文网首页
小程左滑删除 slide-view(二)

小程左滑删除 slide-view(二)

作者: Vergil_wj | 来源:发表于2021-05-25 17:12 被阅读0次

    上一篇小程序左滑删除 movable-view 和 moveable-area(一)已经讲过左滑删除的原理,代码写的比较简单。本篇主要看下第三方组件 slide-veiw左滑实现方式。

    安装第三方 slide-view

    1. 打开终端;
    2. 定位到小程序中project.config.json同级目录,一般也是根目录:
    cd miniprogram 
    
    1. npm 初始化
    npm init -y
    
    • -y:即 yes,加上 -y 直接生成默认的 package.json 文件。如果不加 -y ,则会提示手动填写需要生成的 package.json 文件信息,一般按回车使用默认就可以,加上 -y 则简化了这一步。

    项目初始化完成后,目录下面会自动生成一个 package.json 文件。接下来安装的所有模块及这个模块的版本信息,在这个文件中都有描述。

    如果没有初始化,则在小程序构建 npm 时会提示找不到 npm 包的错误。

    1. 安装 silde-view 组件
    npm install --save miniprogram-slide-view
    
    • --save:依赖包名称(miniprogram-slide-view)自动添加到 package.json 文件 dependencies 键下。如果不写 --save 则需要手动修改 package.json文件。

    安装完成以后,在小程序项目目录下会多出来一个 node_modules 目录,这个目录是本地存放第三方组件源码的目录,所有下载的模块都在这个目录中。

    1. 构建 npm

    微信开发者工具 -> 工具 -> 构建 npm。

    完成后,小程序目录下生成 miniprogram-npm目录。

    这一步是将小程序编译时需要的文件(仅是编译时需要的文件,不是所有),从 node_modules 目录下复制到 miniprogram-npm 目录下。

    使用 slide-view

    1. 在需要使用 slide-view 的页面 page.json 中添加 slide-view 自定义组件配置。
    //.json文件
    {
      "usingComponents": {
        "slide-view": "miniprogram-slide-view"
      }
    }
    

    WXML 文件中引用 slide-view

    <slide-view class="slide" width="750" height="100" slideWidth="300">
      <view class="left" slot="left">这里是插入到组内容</view>
      <view class="right" slot="right">
        <view class="read">已读</view>
        <view class="delete">删除</view>
      </view>
    </slide-view>
    

    slide-view 样式需要在 WXSS 中自定义:

    .left {
      background-color: white;
      height: 100rpx;
      width: 750rpx;
      display: flex;
      flex-direction: row;
      color: grey;
      line-height: 100rpx;
    }
    
    .right {
      height: 100rpx;
      line-height: 100rpx; 
      display: flex;
      text-align: center;
      vertical-align: middle;
      
    }
    
    .read {
      background-color: #ccc;
      color: #fff;
      width: 150rpx;
    }
    
    .delete {
      background-color: red;
      color: #fff;
      width: 150rpx;
    } 
    

    slide-view 实现方式

    查看第三方 slide-view 源码:

    小程序目录node_modules -> miniprogram-slide-view -> src

    WXML 文件:

    <movable-area class="container" style="width: {{width}}rpx; height: {{height}}rpx;">
      <movable-view direction="horizontal" class="movable-view" out-of-bounds="{{out}}" damping="20" x="{{x}}" style="width: {{width + slideWidth}}rpx; height: {{height}}rpx;" inertia bindtouchend="onTouchEnd" bindtouchstart="onTouchStart" bindchange="onChange">
        <view class="left" >
          <slot name= "left"></slot>
        </view>
        <view class= "right">
          <slot name="right"></slot>
        </view>
      </movable-view>
    </movable-area>
    

    slide-view 也是使用 movable-area 和 movable-view 组合实现的左滑删除。原理在小程序左滑删除 movable-view 和 moveable-area(一)这一篇讲过,slide-view 主要是加上了回弹效果。

    JS文件:

        //  当滑动范围超过阈值自动完成剩余滑动
        onTouchEnd(e) {
          this._endX = e.changedTouches[0].pageX
          const {_endX, _startX, _threshold} = this
          if (_endX > _startX && this.data.out === false) return
          if (_startX - _endX >= _threshold) {
            this.setData({
              x: -this._slideWidth
            })
          } else if (_startX - _endX < _threshold && _startX - _endX > 0) {
            this.setData({
              x: 0
            })
          } else if (_endX - _startX >= _threshold) {
            this.setData({
              x: 0
            })
          } else if (_endX - _startX < _threshold && _endX - _startX > 0) {
            this.setData({
              x: -this._slideWidth
            })
          }
        },
    

    这里的判断就是设置一个阈值,根据滑动结束touchend判断滑动的距离是否超过了阈值,如果超过阈值,则左滑,没有超过阈值,则回弹。

    阈值的取值:左滑按钮宽度的一半that._threshold = res.width / 2,源代码如下:

        updateRight() {
          // 获取右侧滑动显示区域的宽度
          const that = this
          const query = wx.createSelectorQuery().in(this)
          query.select('.right').boundingClientRect(function (res) {
            that._slideWidth = res.width
            that._threshold = res.width / 2  //这里是阈值
            that._viewWidth = that.data.width + res.width * (750 / _windowWidth)
            that.setData({
              viewWidth: that._viewWidth
            })
          }).exec()
        },
    

    这是这个组件的实现并不复杂,也是基于小程序官方的可移动区域组件movable-areamovable-view实现的。

    微信团队提供一个更好的实现方式:WeUI 组件库中的 Slideview,没有使用可移动区域组件实现,直接使用的 view 视图容器实现。并且 WeUI 组件库采用扩展声明的方式,直接在小程序中使用,不占用小程序有限的代码包大小,详见小程序左滑删除 WeUI 中 Slideview(三)

    相关文章:

    1. 小程序左滑删除 movable-view 和 moveable-area(一)
    2. 小程序左滑删除 WeUI 中 Slideview(三)

    相关文章

      网友评论

          本文标题:小程左滑删除 slide-view(二)

          本文链接:https://www.haomeiwen.com/subject/dewqsltx.html