原生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.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
控制播放暂停:
给播放暂停按钮绑定点击事件:
isRotate:true
_togglePlay() { var wxauido = document.getElementsByClassName("wx-audio-content")[1]; this.isRotate = !this.isRotate; this.isRotate ? wxauido.play() : wxauido.pause(); },
wx-audio-content为插件生成的节点

浙公网安备 33010602011771号