Vue自定义铃声提示音组件的实现


Posted in Vue.js onJanuary 22, 2022

背景/前言

之前的一个功能需求,需要在页面接收消息,一旦有了新消息之后,需要用铃声进行提醒。

因为没有找到类似的比较便捷的组件,所以就自己写了一个。然后想着能不能尝试下做成一个公共的组件,发布出去让其他开发者也用用?于是就试着写了一个项目(项目地址在最后),发布成了npm包。

目前这个组件已经发布到了npm上,欢迎大家试用。如果有好的建议,或者找到了更好的类似组件,欢迎指出和分享~

下面是使用文档:

组件的使用

安装

npm i easy-ring

加载

1)全局使用

在vue-cli项目main.js上当作插件使用,即可直接在vue单文件组件使用

// main.js
import EasyRing from 'easy-ring'
Vue.use(EasyRing)
<!-- 直接使用,无需引入 -->
<template>
    <easy-ring
        :open="open"
        :ring="ring"
        :src="src"
    />
</template>

export default {
    ...
}

2)import方式

在vue单文件组件里引入

<template>
    <easy-ring
        :open="open"
        :ring="ring"
        :src="src"
    />
</template>

import EasyRing from 'easy-ring'
export default {
    components: {
        EasyRing
    }
    ...
}

组件生效

  • 第一步. 开启铃声:将open参数设为true
  • 第二步. 响铃:将ring参数设为true
  • 第三步. 关铃:将ring参数设为false

PS:

  • 开启铃声这一步,需要放到一个按钮下埋点进行触发(原因解释见下文 "关于open参数的解释")。为了提升自己产品的使用体验,可以做到用户无感知,例如在登录时,用户点击“登录”按钮即可设置open参数为true
  • 根据自己的需求自行决定何时响铃、何时关铃,将ring参数的更改放到对应逻辑下即可

组件参数

参数名 类型 默认值 说明
open Boolean false 开启铃声
ring Boolean false 是否响铃
src String 默认铃声 铃声音频文件地址

使用默认音效

若想使用默认音效,请在./main.js文件中引入默认音效

// main.js
require('easy-ring/easy-ring-default.wav')

然后将这段代码合并到你的vue.config.js配置中:

configureWebpack: {
        module: {
            rules: [
                {
                    test: /easy-ring-default\.(wav)$/i,
                    loader: 'file-loader',
                    options: {
                        name: 'media/[name].[ext]'
                    },
                },
          ]
        }
    }

需要添加这个配置的原因是,vue-cli默认会对所有打包的静态资源加上hash版本号,这样easy-ring就无法获取到你目录下的默认音频文件的地址。

加上这一项file-loader的配置后,easy-ring的默认音频文件就不会带上hash版本号,easy-ring就能找到它。

关于open参数的解释

因为当前多数浏览器不支持自动播放音频,需要用户自己主动触发播放音频才行。这一过程需要放在诸如click的交互事件里,因此我们需要一个按钮之类的东西来触发这一行为。

但是,你可以通过一些交互来设计这一行为,从而提升用户体验,甚至让用户对此无感知。例如:在登录时,在用户点击“登录”按钮时,在代码里设置open参数为true。

项目地址

github上的地址:easy-ring

访问不了github的可以试试这个镜像地址:fastgit镜像

一共有两个项目文件:

  • easy-ring-build:构建npm发布包
  • easy-ring-demo:使用范例

到此这篇关于Vue自定义铃声提示音组件的实现的文章就介绍到这了,更多相关Vue自定义组件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Vue.js 相关文章推荐
vue+vant实现购物车全选和反选功能
Nov 17 Vue.js
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 Vue.js
Vue +WebSocket + WaveSurferJS 实现H5聊天对话交互的实例
Nov 18 Vue.js
element-plus一个vue3.xUI框架(element-ui的3.x 版初体验)
Dec 02 Vue.js
vue 基于abstract 路由模式 实现页面内嵌的示例代码
Dec 14 Vue.js
vue-cli4.0多环境配置变量与模式详解
Dec 30 Vue.js
vue编写简单的购物车功能
Jan 08 Vue.js
Vuex实现简单购物车
Jan 10 Vue.js
vue使用过滤器格式化日期
Jan 20 Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
vue实现水波涟漪效果的点击反馈指令
May 31 Vue.js
vue实现在data里引入相对路径
Jun 05 Vue.js
Vue提供的三种调试方式你知道吗
Jan 18 #Vue.js
详解Vue项目的打包方式(生成dist文件)
Jan 18 #Vue.js
Element-ui Layout布局(Row和Col组件)的实现
Dec 06 #Vue.js
详解gantt甘特图可拖拽、编辑(vue、react都可用 highcharts)
Nov 27 #Vue.js
Vue实现跑马灯样式文字横向滚动
Nov 23 #Vue.js
详解Vue的列表渲染
Nov 20 #Vue.js
详解Vue slot插槽
Nov 20 #Vue.js
You might like
PHP判断文件是否存在、是否可读、目录是否存在的代码
2012/10/03 PHP
php inc文件使用的风险和注意事项
2013/11/12 PHP
php中的mongodb select常用操作代码示例
2014/09/06 PHP
ThinkPHP5.0多个文件上传后找不到临时文件的修改方法
2018/07/30 PHP
Yii框架常见缓存应用实例小结
2019/09/09 PHP
Laravel 框架路由原理与路由访问实例分析
2020/04/14 PHP
javascript hashtable实现代码
2009/10/13 Javascript
JavaScript中获取元素索引的函数
2010/09/10 Javascript
XMLHTTPRequest的属性和方法简介
2010/11/23 Javascript
JavaScript中的私有/静态属性介绍
2012/07/26 Javascript
jquery给图片添加鼠标经过时的边框效果
2013/11/12 Javascript
jQuery制作可自定义大小的拼图游戏
2015/03/30 Javascript
js面向对象之公有、私有、静态属性和方法详解
2015/04/17 Javascript
第一章之初识Bootstrap
2016/04/25 Javascript
用原生JS对AJAX做简单封装的实例代码
2016/07/13 Javascript
JS限制条件补全问题实例分析
2016/12/16 Javascript
js实现本地时间同步功能
2017/08/26 Javascript
React学习笔记之高阶组件应用
2018/06/02 Javascript
js中的闭包实例展示
2018/11/01 Javascript
一次Webpack配置文件的分离实战记录
2018/11/30 Javascript
[02:59]2014DOTA2西雅图国际邀请赛 圆满落幕中国夺冠
2014/07/23 DOTA
研究Python的ORM框架中的SQLAlchemy库的映射关系
2015/04/25 Python
Python3简单实例计算同花的概率代码
2017/12/06 Python
Django中的CBV和FBV示例介绍
2018/02/25 Python
python 编写简单网页服务器的实例
2018/06/01 Python
pygame实现非图片按钮效果
2019/10/29 Python
python 子类调用父类的构造函数实例
2020/03/12 Python
Python startswith()和endswith() 方法原理解析
2020/04/28 Python
党校培训思想汇报
2013/12/30 职场文书
喜之郎果冻广告词
2014/03/20 职场文书
2014法制宣传日活动总结
2014/07/09 职场文书
会议通知范文
2015/04/15 职场文书
2015年幼儿园学前班工作总结
2015/05/18 职场文书
幼儿园开学温馨提示
2015/07/15 职场文书
MySQL数据库中的锁、解锁以及删除事务
2022/05/06 MySQL
Python如何加载模型并查看网络
2022/07/15 Python