为了账号安全,请及时绑定邮箱和手机立即绑定

【金秋打卡】第12天 全新升级,基于Vue3新标准,打造后台综合解决方案 第十二讲

标签:
Vue.js

课程章节: 课程总结

主讲老师: Sunday

课程内容:

今天学习的内容包括:

课程的总结

课程收获:

12.1 心得:

'use strict';

Component({
  properties: {
    item: {
      type: Object,
      // value: {
      //     isPlay:false,
      //     name:'王先生',
      //     recordSrc:'http://ws.stream.qqmusic.qq.com/M500001VfvsJ21xFqb.mp3?guid=ffffffff82def4af4b12b3cd9337d5e7&uin=346897220&vkey=6292F51E1E384E06DCBDC9AB7C49FD713D632D313AC4858BACB8DDD29067D3C601481D36E62053BF8DFEAF74C0A5CCFADD6471160CAF3E6A&fromtag=46',
      //     phone:'13168849257',
      //     type:'安居客来电',
      //     rPersonnel:'万兴',
      //     duration:'30:22',
      //     createTime:'2019-11-11 22:22:12',
      //     curTime:'30:22',
      // }
      observer: 'onDataChange'
    },
    index: {
      type: Number,
      value: "",
    }
  },

  data: {
    curTime: '00:00',
    sliderValue: '',
    pause: false,
  },

  methods: {
    onDataChange: function onDataChange() {
      this.setData({
        item: this.data.item,
      });
    },
    /**
     * 点击播放
     * @param {*} e 
     */
    onClickPlay: function onClickPlay(e) {
      let data = e.currentTarget.dataset.item;
      if (data.isPlay) {
        getApp().getAudioContext().pause();
        this.setData({
          pause: true,
        })
      } else {
        let _this = this;
        getApp().getAudioContext().src = data.recordSrc;
        getApp().getAudioContext().loop = true;
        getApp().getAudioContext().onPlay(function () {
        });//不设置的话可能onTimeUpdate无法触发
        getApp().getAudioContext().onTimeUpdate(function () {
          _this.setData({
            sliderValue: (getApp().getAudioContext().currentTime / getApp().getAudioContext().duration) * 100,
            curTime: _this.formatTime(getApp().getAudioContext().currentTime),
          })
        })
        if (!_this.data.pause) {
          getApp().getAudioContext().stop();
        }
        _this.setData({
          pause: false,
        })
        getApp().getAudioContext().play()
      }
      data.index = this.data.index;
      let clickEvent = {};
      clickEvent.target = 'play';
      data.clickEvent = clickEvent;
      this.triggerEvent('onClickItem', data);
    },

    /**
     * 后退
     * @param {*} e 
     */
    onClickPre: function onClickPre(e) {
      let _this = this;
      let currentTime = getApp().getAudioContext().currentTime - 10;
      if (currentTime < 0) {
        currentTime = 0;
      }
      _this.setData({
        sliderValue: (currentTime / getApp().getAudioContext().duration) * 100,
        curTime: _this.formatTime(currentTime)
      })
      getApp().getAudioContext().seek(currentTime);//通过滑块控制音频进度
    },


    /**
     * 前进
     * @param {*} e 
     */
    onClickNext: function onClickNext(e) {
      let _this = this;
      let currentTime = getApp().getAudioContext().currentTime + 10;
      let duration = getApp().getAudioContext().duration;
      if (currentTime > duration) {
        currentTime = duration;
      }
      _this.setData({
        sliderValue: (currentTime / duration) * 100,
        curTime: _this.formatTime(currentTime)
      })
      getApp().getAudioContext().seek(currentTime);//通过滑块控制音频进度
    },


    /**
     * 监听slider
     */
    onRecordSliderListener: function onRecordSliderListener(e) {
      let _this = this;
      var per = e.detail.value / 100;
      var long = per * getApp().getAudioContext().duration;
      this.setData({
        curTime: _this.formatTime(long)
      })
      getApp().getAudioContext().seek(long);//通过滑块控制音频进度
    },


    /**
     * 时间秒数格式化
     * @param s 时间戳(单位:秒)
     * @returns {*} 格式化后的时分秒
     */
    formatTime: function formatTime(s) {
      var t = '';
      s = parseInt(s);
      if (s > -1) {
        var hour = Math.floor(s / 3600);
        var min = Math.floor(s / 60) % 60;
        var sec = s % 60;
        if (hour < 10) {
          // t = '0' + hour + ":";
        } else {
          t = hour + ":";
        }

        if (min < 10) { t += "0"; }
        t += min + ":";
        if (sec < 10) { t += "0"; }
        t += sec.toFixed(0);
      }
      return t;
    }
  }
});
.container, .content_container, .content,.play_container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-sizing: border-box;
}

.container {
  flex-direction: column;
}

.content_container {
  width: 100%;
  flex-direction: row;
  padding: 32rpx;
}

.content {
  flex-direction: column;
}

.title {
  width: 100%;
  color: #333333;
  font-size: 32rpx;
  font-weight: 500;
  margin-bottom: 8rpx;
  line-height: 44rpx;
}

.des, .time {
  width: 100%;
  color: #BBBBBB;
  font-size: 24rpx;
  font-weight: 500;
  line-height: 36rpx;
}

.play_icon {
  width: 60rpx;
  height: 60rpx;
  flex-shrink: 0;
  margin-left: 10rpx;
}

.play_container {
  background-color: #F9FAFB;
  width: 100%;
  flex-direction: row;
  padding: 24rpx 32rpx;
}


.cur_time{
  flex-shrink: 0;
  color: #BBBBBB;
  font-size: 24rpx;
  line-height: 32rpx;
  margin-right: 30rpx;
}

.record_slider{
  flex-grow: 1;
  margin: 0;
}

.pre ,.next{
  width: 20rpx;
  height: 16rpx;
  flex-shrink: 0;
  margin-left: 28rpx;
}

.line{
  width: 100%;
  background-color: #EEEEEE;
  height: 2rpx;
}
<view class="container">
    <view class="content_container">
        <view class="content">
            <view class="title">{{item.phone+'('+item.name+')'}}</view>
            <view class="des">{{item.type + ' | 接电员 : ' + item.rPersonnel + ' | 通话时间:' + item.duration}} </view>
            <view class="time">{{item.creatTime}}</view>
        </view>
        <image class="play_icon" data-item="{{item}}" class="lazyload" src="" data-original="{{item.isPlay?'/images/ic_record_pause.png':'/images/ic_record_play.png'}}" bindtap="onClickPlay" />
    </view>
    <view class="play_container" wx:if="{{item.isPlay}}">
        <view class="cur_time">{{curTime}}</view>
        <slider class="record_slider" bindchange="onRecordSliderListener" value="{{sliderValue}}" block-size="12" block-color="#00000000"  activeColor="#DDDDDDFF" backgroundColor="#EEEEEEFF"/>
        <image class="pre" class="lazyload" src="" data-original="{{'/images/ic_record_pre.png'}}"  bindtap="onClickPre" />
        <image class="next" class="lazyload" src="" data-original="{{'/images/ic_record_next.png'}}"  bindtap="onClickNext"  />
    </view>
    <view class="line"></view>
</view>

图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消