重写elementUI中的message提示框,解决提示框同时显示多个的问题
第一步:先写一个js文件:
import {
Message
} from 'element-ui';
let messageInstance = null;
const resetMessage = (options) => {
if(messageInstance) {
messageInstance.close()
}
messageInstance = Message(options)
};
['error','success','info','warning'].forEach(type => {
resetMessage[type] = options => {
if(typeof options === 'string') {
options = {
message:options
}
}
options.type = type
return resetMessage(options)
}
})
export const message = resetMessage
第二步,在 main.js 中引入
import ElementUI from 'element-ui';
import 'element-ui/lib/theme-chalk/index.css';
Vue.use(ElementUI);
import {
message
} from './components/js/resetMessage';
Vue.prototype.$message = message; // 这一个操作一定要放在Vue.use(ElementUI) 后面
第三步:使用:
// 在vue组件中代码中调用:
this.$message.error('提示内容');//way1
this.$message({type:success,message:'提示内容'}); //way2
// 在js文件中调用:
import {
message
} from '@/utils/resetMessage';
message({type: 'error',message: '提示内容'});//way1
message.error('提示内容'); //way2
<— 如有不妥,请指正;—>
还没有评论,来说两句吧...