原生js插件 wx-audio (仿微信公众号组件)

 

 

 最近在做一个小功能,电台的语音播放,除了箭头指着的进度条,其他都是自己手写的样式,下面说一下进度条的实现,使用插件 wx-audio

安装

npm 安装

  npm install @dw/wx-audio

引入

import WxAudio from '@dw/wx-audio/lib/wx-audio.css'
  import WxAudio from '@dw/wx-audio'



普通资源引入,先将lib文件下的目录放到自己的项目中,然后根据路径引入

<link href="./wx-audio.css" rel="stylesheet">
<script type="text/javascript" src="wx-audio.js"></script>

文件可自行下载

HTML中在需要生成进度条的地方写一个标签:<div id="textaudio1" style="height: auto; width: 100%;"></div>

使用方法

实例化 音乐组件  (这个audioPlay() 貌似需要放在微信的wx.config下面才能用,所以要先注册一下微信的config,在

wx.ready里面使用,我这个页面做的有微信分享功能,直接在里面调用了,下面贴上我的这部分完整代码

 

                        wx.config({  //sign为getsign接口返回的数据
                            debug: false,
                            appId: sign.appId,
                            timestamp: sign.timestamp,
                            nonceStr: sign.nonceStr,
                            signature: sign.signature,
                            jsApiList: ["onMenuShareTimeline", "onMenuShareAppMessage"]
                        })
                       
                            var src = _this2.articledetail.vid //这里为我另一个接口返回的MP3路径
                            console.log(src)
                            var isAudio = new WxAudio({
                                    ele: "#textaudio1",  //挂在的id为textaudio1的元素
                                    title: "",
                                    disc: "",
                                    src,
                                    width: "100%",
                                    loop: true,
                                    ended: function () {},
                                });
                                console.log(isAudio)
                                isAudio.audioPlay(); //播放
这样做之后,就会在指定的位置生成上面图片中的进度条及下面的时间,进度条可拖拽。
没翻到cdn ,手里有css 和 js文件,索性直接贴上代码,点击 + 展开代码
wx-audio.css

 
@keyframes slidein {
    0% {
      -webkit-transform: translateX(-50%);
      -moz-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      -o-transform: translateX(-50%);
      transform: translateX(-50%);
    }
  
    100% {
      -webkit-transform: translateX(0);
      -moz-transform: translateX(0);
      -ms-transform: translateX(0);
      -o-transform: translateX(0);
      transform: translateX(0);
    }
  }
  
  .wx-audio-content {
    user-select: none;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: auto;
    padding: 8px 12px;
    /* border: 1px solid #efefef; */
    margin: 0 auto;
    font-size: 0;
    box-sizing: border-box;
    font-family: 'PingFangSC-Regular';
    -webkit-tap-highlight-color: transparent;
    /* background: #fdfdfd; */
  }
  
  .wx-audio-content p {
    margin: 0;
  }
  
  .wx-audio-content .wx-audio-info {
    display: none;
  }
  
  .wx-audio-content .wx-audio-left {
    display: inline-block;
    width: 42px;
    height: 100%;
    display: none
  }
  
  .wx-audio-content .wx-audio-left .wx-audio-state {
    width: 100%;
    height: 100%;
    display: none
  }
  
  .wx-audio-content .wx-audio-right {
    display: inline-block;
    width: calc(100% - 42px);
    font-size: 16px;
    box-sizing: border-box;
    padding-left: 10px;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-title {
    padding-bottom: 6px;
    width: 100%;
    font-size: 16px;
    font-weight: 400;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    display: none
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-disc {
    width: 100%;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    padding-bottom: 10px;
    font-size: 12px;
    color: #8c8c8c;
    display: none
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees {
    height: 2px;
    width: calc(100% - 4px);
    position: relative;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-progrees-detail {
    height: 100%;
    width: 100%;
    background: #ebebeb;
    position: relative;
    cursor: pointer;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-progrees-detail .wx-voice-p {
    width: 0%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: hidden;
    background: #FF9424;
    z-index: 2;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-progrees-detail .wx-buffer-p {
    width: 0%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: hidden;
    background: #d9d9d9;
    z-index: 1;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-progrees-detail .wx-loading {
    display: none;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    overflow: hidden;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-progrees-detail .wx-loading .wx-loading-wrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    animation: slidein 6s linear infinite normal;
    -webkit-animation: slidein 6s linear infinite normal;
    -moz-animation: slidein 6s linear infinite normal;
    width: 200%;
    max-width: none !important;
    background-image: -owg-repeating-linear-gradient(-15deg, #d9d9d9, #d9d9d9 2px, #ebebeb 2px, #ebebeb 4px);
    background-image: -webkit-repeating-linear-gradient(-15deg, #d9d9d9, #d9d9d9 2px, #ebebeb 2px, #ebebeb 4px);
    background-image: -moz-repeating-linear-gradient(-15deg, #d9d9d9, #d9d9d9 2px, #ebebeb 2px, #ebebeb 4px);
    background-image: -o-repeating-linear-gradient(-15deg, #d9d9d9, #d9d9d9 2px, #ebebeb 2px, #ebebeb 4px);
    background-image: repeating-linear-gradient(-15deg, #d9d9d9, #d9d9d9 2px, #ebebeb 2px, #ebebeb 4px);
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-audio-origin {
    width: 10px;
    height: 10px;
    margin-top: -5px;
    margin-left: 0;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    background-color: #FF9424;
    position: absolute;
    left: 0;
    top: 50%;
    z-index: 2;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-progrees .wx-audio-origin:before {
    content: " ";
    display: block;
    position: absolute;
    width: 24px;
    height: 24px;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    /* background-image: radial-gradient(rgba(9, 187, 7, 0.3) 20%, transparent 40%); */
    background-image: linear-gradient(-76deg,
        #ff9046 0%,
        #ffac54 75%,
        #ffc762 100%),
      linear-gradient(#ff7437,
        #ff7437 transparent 40%);
    margin-top: -12px;
    margin-left: -9px;
    cursor: pointer;
    outline: 0;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-time {
    width: 100%;
    padding-top: 6px;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    overflow: hidden;
  }
  
  .wx-audio-content .wx-audio-right .wx-audio-time span {
    font-size: 12px;
    color: #8c8c8c;
  }
wx-audio.css

 

wx-audio.js:
var WxAudio = (function(i) {
    var t = {}
    function e(A) {
      if (t[A]) return t[A].exports
      var o = (t[A] = { i: A, l: !1, exports: {} })
      return i[A].call(o.exports, o, o.exports, e), (o.l = !0), o.exports
    }
    return (
      (e.m = i),
      (e.c = t),
      (e.d = function(i, t, A) {
        e.o(i, t) || Object.defineProperty(i, t, { enumerable: !0, get: A })
      }),
      (e.r = function(i) {
        "undefined" != typeof Symbol &&
          Symbol.toStringTag &&
          Object.defineProperty(i, Symbol.toStringTag, { value: "Module" }),
          Object.defineProperty(i, "__esModule", { value: !0 })
      }),
      (e.t = function(i, t) {
        if ((1 & t && (i = e(i)), 8 & t)) return i
        if (4 & t && "object" == typeof i && i && i.__esModule) return i
        var A = Object.create(null)
        if (
          (e.r(A),
          Object.defineProperty(A, "default", { enumerable: !0, value: i }),
          2 & t && "string" != typeof i)
        )
          for (var o in i)
            e.d(
              A,
              o,
              function(t) {
                return i[t]
              }.bind(null, o)
            )
        return A
      }),
      (e.n = function(i) {
        var t =
          i && i.__esModule
            ? function() {
                return i.default
              }
            : function() {
                return i
              }
        return e.d(t, "a", t), t
      }),
      (e.o = function(i, t) {
        return Object.prototype.hasOwnProperty.call(i, t)
      }),
      (e.p = ""),
      e((e.s = 0))
    )
  })([
    function(i, t, e) {
      "use strict"
      Object.defineProperty(t, "__esModule", { value: !0 })
      var A = (function() {
        function i(i, t) {
          for (var e = 0; e < t.length; e++) {
            var A = t[e]
            ;(A.enumerable = A.enumerable || !1),
              (A.configurable = !0),
              "value" in A && (A.writable = !0),
              Object.defineProperty(i, A.key, A)
          }
        }
        return function(t, e, A) {
          return e && i(t.prototype, e), A && i(t, A), t
        }
      })()
      e(3)
      var o = e(1),
        n = e(2),
        r = (function() {
          function i(t) {
            !(function(i, t) {
              if (!(i instanceof t))
                throw new TypeError("Cannot call a class as a function")
            })(this, i)
            ;(this.opt = Object.assign(
              {},
              {
                ele: null,
                width: "320px",
                title: "这是一个测试title",
                src: "",
                disc: "这是一个测试disc",
                autoplay: !1,
                loop: !0,
                ended: function() {}
              },
              t
            )),
              "string" == typeof this.opt.ele &&
                (this.opt.ele = document.querySelector(this.opt.ele)),
              this.opt.ele &&
                ((this.loading = !1),
                (this.isDrag = !1),
                (this.isplaying = !1),
                (this.durationT = 0),
                (this.currentT = 0),
                (this.currentP = 0),
                (this.maxProgressWidth = 0),
                (this.dragProgressTo = 0),
                (this.reduceTBefore = 0),
                (this.reduceTAfter = 0),
                this.initDom())
          }
          return (
            A(i, [
              {
                key: "initDom",
                value: function() {
                  var i = this
                  ;(this.wxAudioC = document.createElement("div")),
                    (this.wxAudioC.className = "wx-audio-content"),
                    (this.wxAudioC.style.width = this.opt.width),
                    this.opt.ele.appendChild(this.wxAudioC),
                    (this.wxAudio = document.createElement("audio")),
                    (this.wxAudio.className = "wx-audio-content"),
                    (this.wxAudio.src = this.opt.src),
                    this.opt.loop &&
                      this.wxAudio.setAttribute("loop", this.opt.loop),
                    this.wxAudioC.appendChild(this.wxAudio),
                    (this.wxAudioL = document.createElement("div")),
                    (this.wxAudioL.className = "wx-audio-left"),
                    this.wxAudioC.appendChild(this.wxAudioL),
                    (this.wxAudioStateImg = document.createElement("img")),
                    (this.wxAudioStateImg.className = "wx-audio-state"),
                    (this.wxAudioStateImg.src = n),
                    this.wxAudioL.appendChild(this.wxAudioStateImg),
                    (this.wxAudioR = document.createElement("div")),
                    (this.wxAudioR.className = "wx-audio-right"),
                    this.wxAudioC.appendChild(this.wxAudioR),
                    (this.wxAudioT = document.createElement("p")),
                    (this.wxAudioT.className = "wx-audio-title"),
                    (this.wxAudioT.innerText = this.opt.title),
                    this.wxAudioR.appendChild(this.wxAudioT),
                    (this.wxAudioD = document.createElement("p")),
                    (this.wxAudioD.className = "wx-audio-disc"),
                    (this.wxAudioD.innerText = this.opt.disc),
                    this.wxAudioR.appendChild(this.wxAudioD),
                    (this.wxAudioP = document.createElement("div")),
                    (this.wxAudioP.className = "wx-audio-progrees"),
                    this.wxAudioR.appendChild(this.wxAudioP),
                    (this.wxAudioDetail = document.createElement("div")),
                    (this.wxAudioDetail.className = "wx-progrees-detail"),
                    this.wxAudioP.appendChild(this.wxAudioDetail),
                    (this.wxVoiceP = document.createElement("span")),
                    (this.wxVoiceP.className = "wx-voice-p"),
                    this.wxAudioDetail.appendChild(this.wxVoiceP),
                    (this.wxBufferP = document.createElement("span")),
                    (this.wxBufferP.className = "wx-buffer-p"),
                    this.wxAudioDetail.appendChild(this.wxBufferP),
                    (this.wxLoading = document.createElement("span")),
                    (this.wxLoading.className = "wx-loading"),
                    this.wxAudioDetail.appendChild(this.wxLoading),
                    (this.wxLoadingWrapper = document.createElement("span")),
                    (this.wxLoadingWrapper.className = "wx-loading-wrapper"),
                    this.wxLoading.appendChild(this.wxLoadingWrapper),
                    (this.wxAudioOrigin = document.createElement("div")),
                    (this.wxAudioOrigin.className = "wx-audio-origin"),
                    this.wxAudioP.appendChild(this.wxAudioOrigin),
                    (this.wxAudioTime = document.createElement("div")),
                    (this.wxAudioTime.className = "wx-audio-time"),
                    this.wxAudioR.appendChild(this.wxAudioTime),
                    (this.wxAudioCurrent = document.createElement("span")),
                    (this.wxAudioCurrent.className = "current-t"),
                    (this.wxAudioCurrent.innerText = "00:00"),
                    this.wxAudioTime.appendChild(this.wxAudioCurrent),
                    (this.wxAudioDuration = document.createElement("span")),
                    (this.wxAudioDuration.className = "duration-t"),
                    (this.wxAudioDuration.innerText = "00:00"),
                    this.wxAudioTime.appendChild(this.wxAudioDuration),
                    this.initAudioEvent(),
                    this.opt.autoplay &&
                      document.addEventListener(
                        "WeixinJSBridgeReady",
                        function() {
                          i.audioPlay()
                        }
                      )
                }
              },
              {
                key: "audioPlay",
                value: function() {
                  this.wxAudio.play(), (this.isPlaying = !0)
                }
              },
              {
                key: "audioPause",
                value: function() {
                  this.wxAudio.pause(), (this.isPlaying = !1)
                }
              },
              {
                key: "audioPlayPause",
                value: function() {
                  this.isPlaying ? this.audioPause() : this.audioPlay()
                }
              },
              {
                key: "audioCut",
                value: function(i, t, e) {
                  ;(this.wxAudio.src = i),
                    (this.wxAudioT.innerText = t),
                    (this.wxAudioD.innerText = e),
                    (this.durationT = 0),
                    (this.currentT = 0),
                    (this.currentP = 0),
                    (this.dragProgressTo = 0),
                    (this.wxAudioCurrent.innerText = "00:00"),
                    (this.wxAudioOrigin.style.left = "0px"),
                    (this.wxVoiceP.style.width = "0px"),
                    this.audioPlay()
                }
              },
              {
                key: "showLoading",
                value: function(i) {
                  ;(this.loading = i || !1),
                    this.loading
                      ? (this.wxLoading.style.display = "block")
                      : (this.wxLoading.style.display = "none")
                }
              },
              {
                key: "initAudioEvent",
                value: function() {
                  var i = this
                  ;(i.wxAudio.onplaying = function() {
                    var t = new Date()
                    ;(i.isPlaying = !0),
                      (i.reduceTBefore =
                        Date.parse(t) - Math.floor(1e3 * i.wxAudio.currentTime)),
                      (i.wxAudioStateImg.src = o)
                  }),
                    (i.wxAudio.onpause = function() {
                      ;(i.isPlaying = !1),
                        i.showLoading(!1),
                        (i.wxAudioStateImg.src = n)
                    }),
                    (i.wxAudio.onloadedmetadata = function() {
                      ;(i.durationT = i.wxAudio.duration),
                        (i.wxAudioDuration.innerText = i.formartTime(
                          i.wxAudio.duration
                        ))
                    }),
                    (i.wxAudio.onwaiting = function() {
                      i.wxAudio.paused || i.showLoading(!0)
                    }),
                    (i.wxAudio.onprogress = function() {
                      if (i.wxAudio.buffered.length > 0) {
                        for (var t = 0, e = 0; e < i.wxAudio.buffered.length; e++)
                          (t +=
                            i.wxAudio.buffered.end(e) -
                            i.wxAudio.buffered.start(e)) > i.durationT &&
                            ((t = i.durationT),
                            i.showLoading(!1),
                            console.log("缓冲完成"))
                        var A = Math.floor((t / i.durationT) * 100)
                        i.wxBufferP.style.width = A + "%"
                      }
                      var o = new Date()
                      i.wxAudio.paused ||
                        ((i.reduceTAfter =
                          Date.parse(o) - Math.floor(1e3 * i.currentT)),
                        i.reduceTAfter - i.reduceTBefore > 1e3
                          ? i.showLoading(!0)
                          : i.showLoading(!1))
                    }),
                    (i.wxAudio.onended = function() {
                      i.opt.ended()
                    }),
                    (i.wxAudio.ontimeupdate = function() {
                      var t = new Date()
                      i.isDrag ||
                        ((i.currentT = i.wxAudio.currentTime),
                        (i.currentP = Number(
                          (i.wxAudio.currentTime / i.durationT) * 100
                        )),
                        (i.reduceTBefore =
                          Date.parse(t) - Math.floor(1e3 * i.currentT)),
                        (i.currentP = i.currentP > 100 ? 100 : i.currentP),
                        (i.wxVoiceP.style.width = i.currentP + "%"),
                        (i.wxAudioOrigin.style.left = i.currentP + "%"),
                        (i.wxAudioCurrent.innerText = i.formartTime(
                          i.wxAudio.currentTime
                        )),
                        i.showLoading(!1))
                    }),
                    (i.wxAudioStateImg.onclick = function() {
                      i.audioPlayPause()
                    }),
                    (i.wxAudioOrigin.onmousedown = function(t) {
                      i.isDrag = !0
                      var e = (t || window.event).clientX,
                        A = t.target.offsetLeft
                      ;(i.maxProgressWidth = i.wxAudioDetail.offsetWidth),
                        (i.wxAudioC.onmousemove = function(t) {
                          if (i.isDrag) {
                            var o = (t || window.event).clientX
                            ;(i.dragProgressTo = Math.min(
                              i.maxProgressWidth,
                              Math.max(0, A + (o - e))
                            )),
                              i.updatePorgress()
                          }
                        }),
                        (i.wxAudioC.onmouseup = function() {
                          i.isDrag &&
                            ((i.isDrag = !1),
                            (i.wxAudio.currentTime = Math.floor(
                              (i.dragProgressTo / i.maxProgressWidth) *
                                i.durationT
                            )))
                        }),
                        (i.wxAudioC.onmouseleave = function() {
                          i.isDrag &&
                            ((i.isDrag = !1),
                            (i.wxAudio.currentTime = Math.floor(
                              (i.dragProgressTo / i.maxProgressWidth) *
                                i.durationT
                            )))
                        })
                    }),
                    (i.wxAudioOrigin.ontouchstart = function(t) {
                      i.isDrag = !0
                      var e = t || window.event,
                        A = e.touches[0].clientX,
                        o = e.target.offsetLeft
                      ;(i.maxProgressWidth = i.wxAudioDetail.offsetWidth),
                        (i.wxAudioC.ontouchmove = function(t) {
                          if (i.isDrag) {
                            var e = (t || window.event).touches[0].clientX
                            ;(i.dragProgressTo = Math.min(
                              i.maxProgressWidth,
                              Math.max(0, o + (e - A))
                            )),
                              i.updatePorgress()
                          }
                        }),
                        (i.wxAudioC.ontouchend = function() {
                          i.isDrag &&
                            ((i.isDrag = !1),
                            (i.wxAudio.currentTime = Math.floor(
                              (i.dragProgressTo / i.maxProgressWidth) *
                                i.durationT
                            )))
                        })
                    }),
                    (i.wxAudioDetail.onclick = function(t) {
                      var e = (t || window.event).layerX,
                        A = i.wxAudioDetail.offsetWidth
                      i.wxAudio.currentTime = Math.floor((e / A) * i.durationT)
                    })
                }
              },
              {
                key: "isWeiXin",
                value: function() {
                  var i = window.navigator.userAgent.toLowerCase()
                  return "micromessenger" === String(i.match(/MicroMessenger/i))
                }
              },
              {
                key: "updatePorgress",
                value: function() {
                  ;(this.wxAudioOrigin.style.left = this.dragProgressTo + "px"),
                    (this.wxVoiceP.style.width = this.dragProgressTo + "px")
                  var i = Math.floor(
                    (this.dragProgressTo / this.maxProgressWidth) * this.durationT
                  )
                  this.wxAudioCurrent.innerText = this.formartTime(i)
                }
              },
              {
                key: "formartTime",
                value: function(i) {
                  var t = function(i) {
                      return (i = i.toString())[1] ? i : "0" + i
                    },
                    e = Math.floor(i / 60),
                    A = Math.floor(i % 60)
                  return t(e) + ":" + t(A)
                }
              }
            ]),
            i
          )
        })()
      t.default = r
    },
    function(i, t) {
      i.exports =
        ""
    },
    function(i, t) {
      i.exports =
        ""
    },
    function(i, t) {}
  ]).default
  
wx-audio.js

 控制播放暂停:

给播放暂停按钮绑定点击事件:

isRotate:true

 

_togglePlay() {
                    var wxauido = document.getElementsByClassName("wx-audio-content")[1];
                    this.isRotate = !this.isRotate;
                    this.isRotate ? wxauido.play() : wxauido.pause();
                },
wx-audio-content为插件生成的节点
 




posted @ 2020-12-05 09:28  王坤龙  阅读(918)  评论(0)    收藏  举报