创建model.js
这里面是一些我们常用的消息提示
import { Message, MessageBox, Notification, Loading } from 'element-ui'
let loadingInstance;
export default {
// 消息提示
msg(content) {
Message.info(content)
},
// 错误消息
msgError(content) {
Message.error(content)
},
// 成功消息
msgSuccess(content) {
Message.success(content)
},
// 警告消息
msgWarning(content) {
Message.warning(content)
},
// 弹出提示
alert(content) {
MessageBox.alert(content, "系统提示")
},
// 错误提示
alertError(content) {
MessageBox.alert(content, "系统提示", { type: 'error' })
},
// 成功提示
alertSuccess(content) {
MessageBox.alert(content, "系统提示", { type: 'success' })
},
// 警告提示
alertWarning(content) {
MessageBox.alert(content, "系统提示", { type: 'warning' })
},
// 通知提示
notify(content) {
Notification.info(content)
},
// 错误通知
notifyError(content) {
Notification.error(content);
},
// 成功通知
notifySuccess(content) {
Notification.success(content)
},
// 警告通知
notifyWarning(content) {
Notification.warning(content)
},
// 确认窗体
confirm(content) {
return MessageBox.confirm(content, "系统提示", {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: "warning",
})
},
// 打开遮罩层
loading(content) {
console.log(content);
loadingInstance = Loading.service({
lock: true,
text: content,
spinner: "el-icon-loading",
background: "rgba(0, 0, 0, 0.7)",
})
},
// 关闭遮罩层
closeLoading() {
loadingInstance.close();
}
}
为了不让它与其他混合在一起,我把它单独拿个js文件出来
创建一个index.js在plugins文件夹下
// 引入我们封装好的js
import modal from './model.js'
export default {
// 这里应该算是传递一个Vue的实例过来
install(Vue) {
// 模态框对象
Vue.prototype.$modal = modal
}
}
在main.js中使用
// 封装的消息提示
import plugins from './plugins/index.js'
// 注意下面这个一定要在引入Elementc插件之前
Vue.use(plugins)
Vue.use(Element)
使用
// 打开loading的加载框
this.$modal.loading('加载中')
// 关闭loading的加载框
this.$modal.closeLoading()