vue中如何使用vue-baberrage生成彈幕
如何使用vue-baberrage生成彈幕
vue-baberrage這個插件本身有好多屬性使用后不生效,不知道是不是自己使用的問題 T_T
安裝彈幕插件;
npm install vue-baberrage --save
創(chuàng)建vue組件,在組件中引用vue-baberrage;
? import Vue from 'vue'; ? import { vueBaberrage, MESSAGE_TYPE } from 'vue-baberrage'; ? Vue.use(vueBaberrage);
html部分;
其中有幾個屬性設(shè)置后不生效,自己測試下吧;
<template> ? <div class="barrages-drop"> ? ? <vue-baberrage ? ? ? :isShow="barrageIsShow" ? ? ? :barrageList="barrageList" ? ? ? :maxWordCount="maxWordCount" ? ? ? :throttleGap="throttleGap" ? ? ? :loop="barrageLoop" ? ? ? :boxHeight="boxHeight" ? ? ? :messageHeight="messageHeight" ? ? > ? ? </vue-baberrage> ? </div> </template>
javaScript部分;
<script> ? import Vue from 'vue'; ? import { vueBaberrage, MESSAGE_TYPE } from 'vue-baberrage'; ? Vue.use(vueBaberrage); ? export default { ? ? name: 'barrages', ? ? //接收父組件傳遞過來的數(shù)組數(shù)據(jù) ? ? props:{ ? ? ? barrage:{ ? ? ? ? type:Array, ? ? ? ? required:true ? ? ? } ? ? }, ? ? data() { ? ? ? return { ? ? ? ? barrageIsShow: true, ? ? ? ? messageHeight: 50, ? ? ? ? boxHeight: 150, ? ? ? ? barrageLoop: true, ? ? ? ? boxWidth:800, ? ? ? ? ? //彈幕寬度 ? ? ? ? maxWordCount: 300, ? ? ? ? throttleGap: 5000, ? ? ? //消息間隔 ? ? ? ? barrageList: [], ? ? ? ? barrage1: [], ? ? ? }; ? ? }, ? ? //因為父組件那邊接口執(zhí)行會比組件生成慢,所以用watch監(jiān)聽賦值 ? ? watch: { ? ? ? barrage: function(newVal,oldVal){ ? ? ? ? this.barrage1 = newVal; ? ? ? ? this.addToList(); ? ? ? } ? ? }, ? ? mounted() { ? ? }, ? ? methods: { ? ? ? addToList() { ? ? ? ? console.log(this.barrage1) ? ? ? ? this.barrage1.forEach((v) => { ? ? ? ? ? this.barrageList.push({ ? ? ? ? ? ? id: Math.round(Math.random()*5000), ? ? ? ? ? ? msg: v, ? ? ? ? ? ? time: this.randomNum(3,10), ? ? ? ? ? ? type: MESSAGE_TYPE.NORMAL, ? ? ? ? ? ? barrageStyle: '' ? ? ? ? ? }); ? ? ? ? }); ? ? ? }, ? ? ? // 生成指定隨機數(shù),作用于每條彈幕的速度 ? ? ? randomNum(minNum,maxNum){ ? ? ? ? switch(arguments.length){ ? ? ? ? ? case 1: ? ? ? ? ? ? return parseInt(Math.random()*minNum+1,10); ? ? ? ? ? ? break; ? ? ? ? ? case 2: ? ? ? ? ? ? return parseInt(Math.random()*(maxNum-minNum+1)+minNum,10); ? ? ? ? ? ? break; ? ? ? ? ? default: ? ? ? ? ? ? return 0; ? ? ? ? ? ? break; ? ? ? ? } ? ? ? } ? ? } ? } </script>
css部分;
<style lang="scss"> ? .baberrage-item{ ? ? /*height: .5rem!important;*/ ? } ? //強行改變彈幕背景色 ? .baberrage-item .normal{ ? ? background: rgba(0,0,0,0.3)!important; ? } ? .normal{ ? ? .baberrage-msg{ ? ? ? /*padding: .1rem!important;*/ ? ? } ? ? .baberrage-avatar{ ? ? ? display: none; ? ? } //彈幕前頭像不展示 ? ? img{ ?? ? ? ? display: none; ? ? } ? } ? .baberrage-avatar{ ? ? img{ ? ? ? width: 20px !important; ? ? ? height: 20px!important; ? ? } ? } ? .barrages-drop { ? ? .blue { ? ? ? border-radius: 100px; ? ? ? background: #e6ff75; ? ? ? color: #fff; ? ? } ? ? .green { ? ? ? border-radius: 100px; ? ? ? background: #75ffcd; ? ? ? color: #fff; ? ? } ? ? .red { ? ? ? background: rgba(0,0,0,0.1); ? ? ? color: red; ? ? } ? ? .yellow { ? ? ? border-radius: 100px; ? ? ? background: #dfc795; ? ? ? color: #fff; ? ? } ? ? .baberrage-stage { ? ? ? position: absolute; ? ? ? width: 100%; ? ? ? overflow: hidden; ? ? ? top: 0; ? ? } ? } </style>
就這把,都是我改過原來的樣式,跟原本的有差距,想要原本樣式,可以查看他的文檔
git文檔地址:https://gitee.com/hoseapps/vue-baberrage
vue彈幕實現(xiàn)及優(yōu)化
起因: 活動需求需要使用彈幕的形式展示內(nèi)容
解決: 首先是找到一個vue-baberrage
然后使用起來看起來也沒有什么問題,最后當我打開瀏覽器rendering的paint flash發(fā)現(xiàn)重繪嚴重
最后找到一個vue-danmaku 組件,發(fā)現(xiàn)不會頻繁重繪
定位:彈幕移動使用transform改變位置,并使用will-change進行優(yōu)化
will-change屬性通過告訴瀏覽器什么屬性、什么元素將會發(fā)生變化,可以對這些操作進行可能性的優(yōu)化,由此提高CSS動畫的執(zhí)行效率
大量的節(jié)點動畫渲染可以選擇canvas或者webgl進行開發(fā)
聲明: 我不是這兩者的開發(fā)者,只是使用者,如有錯誤,歡迎指出
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中如何實現(xiàn)在線預(yù)覽word文件、excel文件
這篇文章主要介紹了Vue中如何實現(xiàn)在線預(yù)覽word文件、excel文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題)
本文主要介紹了Vue3封裝自動滾動列表指令(含網(wǎng)頁縮放滾動問題),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-05-05vue項目完成后如何實現(xiàn)項目優(yōu)化的示例
本文主要介紹了vue項目完成后如何實現(xiàn)項目優(yōu)化的示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12