├── .babelrc ├── example ├── pages │ └── index │ │ ├── main.json │ │ ├── main.js │ │ └── index.vue ├── App.vue ├── app.json └── main.js ├── .postcssrc.js ├── .gitignore ├── index.html ├── project.config.json ├── package.json ├── src ├── registry.js ├── icons.js └── index.vue └── README.md /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": "env" 3 | } 4 | -------------------------------------------------------------------------------- /example/pages/index/main.json: -------------------------------------------------------------------------------- 1 | { 2 | "navigationBarTitleText": "demo 页" 3 | } 4 | -------------------------------------------------------------------------------- /example/App.vue: -------------------------------------------------------------------------------- 1 | 6 | -------------------------------------------------------------------------------- /example/pages/index/main.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import App from './index' 3 | 4 | const app = new Vue(App) 5 | app.$mount() 6 | -------------------------------------------------------------------------------- /example/app.json: -------------------------------------------------------------------------------- 1 | { 2 | "pages": [ 3 | "pages/index/main" 4 | ], 5 | "window": { 6 | "navigationBarTitleText": "mp-toast test" 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /.postcssrc.js: -------------------------------------------------------------------------------- 1 | // https://github.com/michael-ciniawsky/postcss-load-config 2 | 3 | module.exports = { 4 | "plugins": { 5 | "postcss-mpvue-wxss": {} 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules/ 3 | dist/ 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | 8 | # Editor directories and files 9 | .idea 10 | *.suo 11 | *.ntvs* 12 | *.njsproj 13 | *.sln 14 | -------------------------------------------------------------------------------- /index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | mptoast 6 | 7 | 8 |
9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /example/main.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import App from './App' 3 | 4 | import mpvueToastRegistry from '../src/registry' 5 | mpvueToastRegistry(Vue) 6 | 7 | Vue.config.productionTip = false 8 | App.mpType = 'app' 9 | 10 | const app = new Vue(App) 11 | app.$mount() 12 | 13 | export default { 14 | // 这个字段走 app.json 15 | config: { 16 | // 页面前带有 ^ 符号的,会被编译成首页,其他页面可以选填,我们会自动把 webpack entry 里面的入口页面加进去 17 | pages: ['^pages/example/main'], 18 | window: { 19 | backgroundTextStyle: 'light', 20 | navigationBarBackgroundColor: '#fff', 21 | navigationBarTitleText: 'WeChat', 22 | navigationBarTextStyle: 'black' 23 | } 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /project.config.json: -------------------------------------------------------------------------------- 1 | { 2 | "description": "项目配置文件", 3 | "packOptions": { 4 | "ignore": [] 5 | }, 6 | "setting": { 7 | "urlCheck": true, 8 | "es6": true, 9 | "postcss": true, 10 | "minified": true, 11 | "newFeature": true, 12 | "autoAudits": false 13 | }, 14 | "compileType": "miniprogram", 15 | "libVersion": "2.0.4", 16 | "appid": "wxca65ed4ae828b9f3", 17 | "projectname": "mptoast", 18 | "debugOptions": { 19 | "hidedInDevtools": [] 20 | }, 21 | "isGameTourist": false, 22 | "condition": { 23 | "search": { 24 | "current": -1, 25 | "list": [] 26 | }, 27 | "conversation": { 28 | "current": -1, 29 | "list": [] 30 | }, 31 | "game": { 32 | "currentL": -1, 33 | "list": [] 34 | }, 35 | "miniprogram": { 36 | "current": -1, 37 | "list": [] 38 | } 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /example/pages/index/index.vue: -------------------------------------------------------------------------------- 1 | 7 | 8 | 31 | 32 | 43 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "mptoast", 3 | "version": "1.3.0", 4 | "description": "a toast component for mpvue", 5 | "main": "src/index.vue", 6 | "files": [ 7 | "src" 8 | ], 9 | "repository": { 10 | "url": "https://github.com/noahlam/mpvue-toast.git", 11 | "type": "git" 12 | }, 13 | "author": "noahlam <284516433@qq.com>", 14 | "license": "MIT", 15 | "scripts": { 16 | "dev": "node build/dev-server.js", 17 | "start": "node build/dev-server.js", 18 | "build": "node build/build.js" 19 | }, 20 | "dependencies": { 21 | "mpvue": "^1.0.11", 22 | "vuex": "^3.0.1" 23 | }, 24 | "devDependencies": { 25 | "babel-core": "^6.22.1", 26 | "babel-loader": "^7.1.1", 27 | "babel-preset-env": "^1.3.2", 28 | "copy-webpack-plugin": "^4.5.1", 29 | "css-loader": "^0.28.11", 30 | "express": "^4.16.3", 31 | "extract-text-webpack-plugin": "^3.0.2", 32 | "glob": "^7.1.2", 33 | "html-webpack-plugin": "^3.2.0", 34 | "http-proxy-middleware": "^0.18.0", 35 | "mpvue-loader": "^1.1.2", 36 | "mpvue-template-compiler": "^1.0.11", 37 | "mpvue-webpack-target": "^1.0.0", 38 | "ora": "^2.0.0", 39 | "postcss-mpvue-wxss": "^1.0.0", 40 | "px2rpx-loader": "^0.1.10", 41 | "relative": "^3.0.2", 42 | "url-loader": "^1.0.1", 43 | "vue-style-loader": "^4.1.0", 44 | "webpack": "^3.11.0", 45 | "webpack-dev-middleware-hard-disk": "^1.12.1", 46 | "webpack-merge": "^4.1.0", 47 | "webpack-mpvue-asset-plugin": "^0.1.1" 48 | }, 49 | "engines": { 50 | "node": ">= 4.0.0", 51 | "npm": ">= 3.0.0" 52 | }, 53 | "browserslist": [ 54 | "> 1%", 55 | "last 2 versions", 56 | "not ie <= 8" 57 | ] 58 | } 59 | -------------------------------------------------------------------------------- /src/registry.js: -------------------------------------------------------------------------------- 1 | // 注册 2 | import Vuex from 'vuex' 3 | 4 | export default function registry(v) { 5 | v.use(Vuex) 6 | // 挂在store到全局(this) 7 | v.prototype.$toastStore = new Vuex.Store({ 8 | state: { 9 | show:false, 10 | text:'提示', 11 | duration: 1500, 12 | textClass:null, 13 | icon:null, 14 | iconClass:null, 15 | callback: null 16 | }, 17 | getters:{ 18 | 'GET_TOAST_SHOW': function (state) { 19 | return state.show 20 | }, 21 | 'GET_TOAST_TEXT': function (state) { 22 | return state.text 23 | }, 24 | 'GET_TOAST_DURATION': function (state) { 25 | return state.duration 26 | }, 27 | 'GET_TOAST_TEXT_CLASS_NAME': function (state) { 28 | return state.textClass 29 | }, 30 | 'GET_TOAST_ICON': function (state) { 31 | return state.icon 32 | }, 33 | 'GET_TOAST_ICON_CLASS_NAME': function (state) { 34 | return state.iconClass 35 | }, 36 | 37 | 38 | }, 39 | mutations: { 40 | hideToast(state) { 41 | state.show = false 42 | }, 43 | showToast(state, data) { 44 | if (state.show) return 45 | data.duration = data.duration || 1500 46 | let dt = { 47 | show: true, 48 | text: data.text || '提示', 49 | duration: data.duration + 700, 50 | textClass: data.textClass || '', 51 | icon:data.icon || '', 52 | iconClass:data.iconClass || '', 53 | callback: data.callback || null 54 | } 55 | state = Object.assign(state, dt) 56 | }, 57 | callback(state) { 58 | let cb = state.callback 59 | cb && cb() 60 | } 61 | } 62 | }) 63 | // 注册显示方法 $mptoast 到全局 64 | v.prototype.$mptoast = function (data, icon = '', duration = 1500, textClass = '',iconClass = '', callback = null) { 65 | if (typeof data === 'string' || typeof data === 'number') { 66 | let _data = { 67 | text: data, 68 | icon, 69 | duration, 70 | textClass, 71 | iconClass, 72 | callback 73 | } 74 | v.prototype.$toastStore.commit('showToast', _data) 75 | } 76 | if (typeof data === 'object') { 77 | v.prototype.$toastStore.commit('showToast', data) 78 | } 79 | } 80 | } 81 | -------------------------------------------------------------------------------- /src/icons.js: -------------------------------------------------------------------------------- 1 | let success = `` 2 | let error = `` 3 | let info = `` 4 | export default { 5 | success, 6 | error, 7 | info 8 | } 9 | -------------------------------------------------------------------------------- /src/index.vue: -------------------------------------------------------------------------------- 1 | 7 | 8 | 56 | 57 | 102 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ### 介绍 2 | mptoast 是一个基于mpvue的简单弹窗组件 github地址:[https://github.com/noahlam/mpvue-toast](https://github.com/noahlam/mpvue-toast) 3 | 4 | ### 特性 5 | 0. **轻量** 目前整个项目`未打包前`大概只有`120行`代码(包括注释),5kb左右(包括图标) 6 | 1. **配置少** 尝试过无数种优化方法,只为减少配置 7 | 2. **冗余少** 每个页面(page)只需要引入一次,该页面里面如果有多个子组件,可以跟页面共用一个,无需重复引入。 8 | 3. **使用简单** 除了必须的在page页面对组件import,注册,和html引入(这些麻烦的东西由于mpvue不支持的原因,暂时无法做到优化),其他的使用只需一行简单的代码 `this.$mptoast('提示消息‘)`即可实现弹窗 9 | 4. **可定制性强** 提供用户重写样式的属性,只需传入一个定义好的`样式类名`既可实现对原有样式的覆盖(具体请看参数说明) 10 | 11 | 12 | ### 安装 13 | 14 | 1.安装`vuex`,如果你项目还没使用的话。请放心,虽然`mptoast`依赖`vuex`,你不会接触到任何有关`vuex`的代码。添加`vuex`只为让你写更少的代码。 15 | 16 | npm i vuex 17 | 18 | 2.安装`mptoast` 19 | 20 | npm i mptoast -D 21 | 22 | 或者 23 | 24 | yarn add mptoast --dev 25 | 26 | 3.在项目的主配置文件`(一般位于src/main.js)`加入以下代码 27 | 28 | import mpvueToastRegistry from 'mptoast/src/registry' 29 | mpvueToastRegistry(Vue) 30 | 31 | 4.在你需要弹窗的页面,引入组件,并注册,然后在页面内加入一个你注册的组件,就可以在js里面调用`this.$mptoast()`了, 以下是一个简单的实例 32 | 33 | 39 | 40 | 57 | 58 | 至于为什么没办法做到像vue组件那样,引入一次,就可以在所有页面使用,我想我必须得解释以下,因为mpvue目前还不支持全局的组件,我尝试过很多种变通办法,都行不通,甚至为了让大家使用的时候,少输入几个字,少一些冗余,我都做了很多尝试和优化,目前mpvue团队已经在考虑新增全局组件功能,我会时刻关注,一旦支持,我这边也立马做支持。 59 | 60 | ### 参数说明 61 | > 参数分2种类型,一种是多个参数,另一个种则少只接收一个对象 62 | 63 | 一, 多个参数 64 | 65 | | 参数位置 | 参数类型 | 参数名称 |是否必填 | 默认值 | 其他说明 | 66 | |:-------:|:------:|:------:|:-------:|:-------:|:-----------| 67 | | 1 | string | 显示文本 | 是 | - | 如果第一个参数不是string或number类型
则会被当作对象来处理,也就是上面提到的另一种情况 | 68 | | 2 | stirng | 显示图标类型 | 否 | - | 3种可选 'success' , 'error' , 'info' | 69 | | 3 | number | 关闭时间 | 否 | 1500 | 单位是毫秒ms,传其他格式(非number类型)会报错 | 70 | | 4 | string | 文本样式类名 | 否 | - | 如果需要自定义显示的样式,请先定一个样式类
然后把类名传给该参数,定义类的时候
如果所有页面都使用这个类,必须定义为全局的
如果定义在scope作用域内的话
子组件不能复用父组件的样式。 | 71 | | 5 | string | icon样式类名 | 否 | - | 同上,需要注意的是icon是包含在文本里面的 | 72 | | 6 |function| 回掉函数 | 否 | - | toast 隐藏时的回调hanshu | 73 | 74 | 以下代码是一个多个参数调用的简单实例 75 | 76 | this.$mptoast('温馨提示', 'success', 2000) 77 | 78 | 二, 单个object对象 79 | object对象参数的功能,其实跟上面`多个参数`的对应的功能是一样的,只是写法不同而已,我们直接看代码 80 | 81 | this.$mptoast({ 82 | text: '温馨提示', // 显示文本 83 | icon:'success' // 图标类型 84 | duration: 2000, // 关闭时间 85 | textClass: 'my-class' // 样式类名 86 | iconClass: 'icon-class' // 图标类名 87 | callback: () => { console.log('隐藏')} 88 | }) 89 | 90 | 需要注意的是,以上参数,如果传入错误的类型,先会进行类型转换,如果转换失败的,可能会报错。 91 | --------------------------------------------------------------------------------