VUE页面声音+标题闪烁通知组件怎么使用

其他教程   发布日期:2023年08月27日   浏览次数:473

这篇文章主要介绍“VUE页面声音+标题闪烁通知组件怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“VUE页面声音+标题闪烁通知组件怎么使用”文章能帮助大家解决问题。

一个VUE页面声音+标题闪烁通知的组件

1、使用方法

1.1 组件模板引用

  1. <PageNotice ref="pageNotice" sound="/xxx/new_message.mp3" />

1.2 支持的参数

sound: 通知时播放的声音

1.3 动态调用方法

  1. $refs.pageNotice.tip('你好','新消息') $refs.pageNotice.tip('有新客户访问')

2、组件源码

PageNotice 组件源代码如下

  1. <template>
  2. <div>
  3. <audio ref="audio" :src="sound"></audio>
  4. </div>
  5. </template>
  6. <script>
  7. export default {
  8. name: "PageNotice",
  9. props: {
  10. sound: {
  11. type: String,
  12. default: ''
  13. },
  14. },
  15. data() {
  16. return {
  17. tipTimer: null,
  18. tipTimerCount: 0,
  19. titleOld: null,
  20. }
  21. },
  22. methods: {
  23. tip(msg, type) {
  24. this.doPageTitle(msg, type)
  25. if (this.sound) {
  26. this.doPlaySound()
  27. }
  28. },
  29. doClearTimer() {
  30. clearInterval(this.tipTimer)
  31. this.tipTimer = null
  32. if (this.titleOld) {
  33. window.document.title = this.titleOld
  34. }
  35. this.tipTimerCount = 0
  36. },
  37. doPageTitle(msg, type) {
  38. type = type || '提醒'
  39. if (this.tipTimer) {
  40. this.doClearTimer()
  41. }
  42. this.titleOld = document.title
  43. this.tipTimerCount = 0
  44. this.tipTimer = setInterval(() => {
  45. this.tipTimerCount++
  46. if (this.tipTimerCount % 2 === 0) {
  47. window.document.title = '【' + type + '】' + msg
  48. } else {
  49. window.document.title = '' + msg
  50. }
  51. if (this.tipTimerCount > 6) {
  52. this.doClearTimer()
  53. }
  54. }, 500)
  55. },
  56. doPlaySound() {
  57. let audio = this.$refs.audio
  58. if (!audio) {
  59. return
  60. }
  61. try {
  62. audio.pause()
  63. audio.play()
  64. } catch (e) {
  65. }
  66. }
  67. }
  68. }
  69. </script>

以上就是VUE页面声音+标题闪烁通知组件怎么使用的详细内容,更多关于VUE页面声音+标题闪烁通知组件怎么使用的资料请关注九品源码其它相关文章!