基于mpvue的简单弹窗组件mptoast使用详解


Posted in Javascript onAugust 02, 2019

介绍

mptoast 是一个基于mpvue的简单弹窗组件 github地址: https://github.com/noahlam/mpvue-toast

特性

1.轻量 目前整个项目未打包前大概只有120行代码(包括注释),5kb左右(包括图标)

2.配置少 尝试过无数种优化方法,只为减少配置

3.冗余少 每个页面(page)只需要引入一次,该页面里面如果有多个子组件,可以跟页面共用一个,无需重复引入。

4.使用简单 除了必须的在page页面对组件import,注册,和html引入(这些麻烦的东西由于mpvue不支持的原因,暂时无法做到优化),其他的使用只需一行简单的代码 this.$mptoast('提示消息‘)即可实现弹窗

5.可定制性强 提供用户重写样式的属性,只需传入一个定义好的样式类名既可实现对原有样式的覆盖(具体请看参数说明)

安装

1.安装vuex,如果你项目还没使用的话。请放心,虽然mptoast依赖vuex,你不会接触到任何有关vuex的代码。添加vuex只为让你写更少的代码。

npm i vuex

2.安装mptoast

npm i mptoast -D

或者

yarn add mptoast --dev

3.在项目的主配置文件(一般位于src/main.js)加入以下代码

import mpvueToastRegistry from 'mptoast'
mpvueToastRegistry(Vue)

4.在你需要弹窗的页面,引入组件,并注册,然后在页面内加入一个你注册的组件,就可以在js里面调用this.$mptoast()了, 以下是一个简单的实例

<template>
 <div>
  <-- 省略其他代码 -->
  <mptoast />
 </div>
</template>

<script>
import mptoast from 'mptoast'

export default {
 components: {
  mptoast
 },
 data () {
  return {}
 },
 methods: {
  showToast () {
   this.$mptoast('我是提示信息')
  },
 }
}
</script>

至于为什么没办法做到像vue组件那样,引入一次,就可以在所有页面使用,我想我必须得解释以下,因为mpvue目前还不支持全局的组件,我尝试过很多种变通办法,都行不通,甚至为了让大家使用的时候,少输入几个字,少一些冗余,我都做了很多尝试和优化,目前mpvue团队已经在考虑新增全局组件功能,我会时刻关注,一旦支持,我这边也立马做支持。

参数说明

参数分2种类型,一种是多个参数,另一个种则少只接收一个对象

一, 多个参数

参数位置 参数类型 参数名称 是否必填 默认值 其他说明
1 string 显示文本 - 如果第一个参数不是string或number类型 则会被当作对象来处理,也就是上面提到的另一种情况
2 stirng 显示图标类型 - 3种可选 'success' , 'error' , 'info'
3 number 关闭时间 1500 单位是毫秒ms,传其他格式(非number类型)会报错
4 string 文本样式类名 - 如果需要自定义显示的样式,请先定一个样式类 然后把类名传给该参数,定义类的时候 如果所有页面都使用这个类,必须定义为全局的 如果定义在scope作用域内的话 子组件不能复用父组件的样式。
5 string icon样式类名 - 同上,需要注意的是icon是包含在文本里面的

同上,需要注意的是icon是包含在文本里面的

以下代码是一个多个参数调用的简单实例

this.$mptoast('温馨提示', 'success', 2000)

二, 单个object对象

object对象参数的功能,其实跟上面多个参数的对应的功能是一样的,只是写法不同而已,我们直接看代码

this.$mptoast({
 text: '温馨提示',    // 显示文本
 icon:'success'     // 图标类型
 duration: 2000,    // 关闭时间
 textClass: 'my-class'  // 样式类名
 iconClass: 'icon-class' // 图标类名
})

需要注意的是,以上参数,如果传入错误的类型,先会进行类型转换,如果转换失败的,可能会报错。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 闭包在封装函数时的简单分析
Nov 28 Javascript
JQuery触发事件例如click
Sep 11 Javascript
浅谈JavaScript异常处理语句
Jun 26 Javascript
详细分析Javascript中创建对象的四种方式
Aug 17 Javascript
jQuery实现鼠标经过显示动画边框特效
Mar 24 jQuery
Vue.js 时间转换代码及时间戳转时间字符串
Oct 16 Javascript
使用mpvue搭建一个初始小程序及项目配置方法
Dec 03 Javascript
vue下载excel的实现代码后台用post方法
May 10 Javascript
解决layui表格的表头不滚动的问题
Sep 04 Javascript
vue使用一些外部插件及样式的配置代码
Nov 18 Javascript
JavaScript实现轮播图特效
Apr 10 Javascript
使用Mock.js生成前端测试数据
Dec 13 Javascript
vue下使用nginx刷新页面404的问题解决
Aug 02 #Javascript
超轻量级的js时间库miment使用解析
Aug 02 #Javascript
操作按钮悬浮固定在微信小程序底部的实现代码
Aug 02 #Javascript
微信小程序中悬浮窗功能的实现代码
Aug 02 #Javascript
微信小程序的授权实现过程解析
Aug 02 #Javascript
jQuery实现input[type=file]多图预览上传删除等功能
Aug 02 #jQuery
用 js 写一个 js 解释器过程详解
Aug 02 #Javascript
You might like
php include和require的区别深入解析
2013/06/17 PHP
Javascript写了一个清除“logo1_.exe”的杀毒工具(可扫描目录)
2007/02/09 Javascript
JS中产生20位随机数以0-9为例也可以是a-z A-Z
2014/08/01 Javascript
jquery渐隐渐显的图片幻灯闪烁切换实现方法
2015/02/26 Javascript
深入理解React中es6创建组件this的方法
2016/08/29 Javascript
微信和qq时间格式模板实例详解
2016/10/21 Javascript
jquery mobile移动端幻灯片滑动切换效果
2020/04/15 Javascript
详谈Angular 2+ 的表单(一)之模板驱动型表单
2017/04/25 Javascript
React进阶学习之组件的解耦之道
2017/08/07 Javascript
react native带索引的城市列表组件的实例代码
2017/08/08 Javascript
jQuery 中msgTips 顶部弹窗效果实现代码
2017/08/14 jQuery
JS和Canvas实现图片的预览压缩和上传功能
2018/03/30 Javascript
在vue-cli的组件模板里使用font-awesome的两种方法
2018/09/28 Javascript
Nautil 中使用双向数据绑定的实现
2019/10/02 Javascript
jquery 键盘事件 keypress() keydown() keyup()用法总结
2019/10/23 jQuery
vue 使用鼠标滚动加载数据的例子
2019/10/31 Javascript
python清理子进程机制剖析
2017/11/23 Python
Python语言实现百度语音识别API的使用实例
2017/12/13 Python
利用Python如何批量更新服务器文件
2018/07/29 Python
基于pycharm导入模块显示不存在的解决方法
2018/10/13 Python
Python3 利用requests 库进行post携带账号密码请求数据的方法
2018/10/26 Python
在python 不同时区之间的差值与转换方法
2019/01/14 Python
在Python中将函数作为另一个函数的参数传入并调用的方法
2019/01/22 Python
Python递归函数实例讲解
2019/02/27 Python
Python求均值,方差,标准差的实例
2019/06/29 Python
python 随机森林算法及其优化详解
2019/07/11 Python
Python3.x+迅雷x 自动下载高分电影的实现方法
2020/01/12 Python
python文件路径操作方法总结
2020/12/21 Python
浅谈HTML5新增和废弃的标签
2019/04/28 HTML / CSS
钉钉企业内部H5微应用开发详解
2020/05/12 HTML / CSS
医院办公室主任职责
2013/12/29 职场文书
珍爱生命演讲稿
2014/05/10 职场文书
《巨人的花园》教学反思
2016/02/19 职场文书
2019年12月24日平安夜祝福语集锦
2019/12/24 职场文书
用 Python 元类的特性实现 ORM 框架
2021/05/19 Python
python用海龟绘图写贪吃蛇游戏
2021/06/18 Python