Rumah > hujung hadapan web > View.js > Kongsi komponen pemberitahuan denyar bunyi halaman VUE + tajuk

Kongsi komponen pemberitahuan denyar bunyi halaman VUE + tajuk

藏色散人
Lepaskan: 2023-03-14 17:28:38
ke hadapan
1544 orang telah melayarinya

Artikel ini membawakan anda pengetahuan yang berkaitan tentang VUE terutamanya berkongsi dengan anda komponen bunyi halaman VUE + pemberitahuan flash tajuk. Saya harap ia dapat membantu semua orang.

Kongsi komponen pemberitahuan denyar bunyi halaman VUE + tajuk

Bunyi halaman VUE + komponen pemberitahuan kilat tajuk

1. Cara menggunakan

1.1 Templat komponen Petikan

<PageNotice ref="pageNotice" sound="/xxx/new_message.mp3" />
Salin selepas log masuk

1.2 Parameter yang disokong

bunyi: bunyi yang dimainkan semasa pemberitahuan

1.3 Kaedah panggilan dinamik

$refs.pageNotice.tip(&#39;你好&#39;,&#39;新消息&#39;) $refs.pageNotice.tip(&#39;有新客户访问&#39;)
Salin selepas log masuk

2

Kod sumber komponen PageNotice adalah seperti berikut

<template>
    <div>
        <audio ref="audio" :src="sound"></audio>
    </div>
</template>
<script>
export default {
    name: "PageNotice",
    props: {
        sound: {
            type: String,
            default: &#39;&#39;
        },
    },
    data() {
        return {
            tipTimer: null,
            tipTimerCount: 0,
            titleOld: null,
        }
    },
    methods: {
        tip(msg, type) {
            this.doPageTitle(msg, type)
            if (this.sound) {
                this.doPlaySound()
            }
        },
        doClearTimer() {
            clearInterval(this.tipTimer)
            this.tipTimer = null
            if (this.titleOld) {
                window.document.title = this.titleOld
            }
            this.tipTimerCount = 0
        },
        doPageTitle(msg, type) {
            type = type || &#39;提醒&#39;
            if (this.tipTimer) {
                this.doClearTimer()
            }
            this.titleOld = document.title
            this.tipTimerCount = 0
            this.tipTimer = setInterval(() => {
                this.tipTimerCount++
                if (this.tipTimerCount % 2 === 0) {
                    window.document.title = &#39;【&#39; + type + &#39;】&#39; + msg
                } else {
                    window.document.title = &#39;&#39; + msg
                }
                if (this.tipTimerCount > 6) {
                    this.doClearTimer()
                }
            }, 500)
        },
        doPlaySound() {
            let audio = this.$refs.audio
            if (!audio) {
                return
            }
            try {
                audio.pause()
                audio.play()
            } catch (e) {
            }
        }
    }
}
</script>
Salin selepas log masuk

Pembelajaran yang disyorkan: "tutorial video vue.js"

Atas ialah kandungan terperinci Kongsi komponen pemberitahuan denyar bunyi halaman VUE + tajuk. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
vue
sumber:learnku.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan