React实现全局组件的Toast轻提示效果
程序员文章站
2022-06-28 23:46:56
toast是常用的轻提示弹框,常用于页面loading和提示语弹窗。
本例基于react实现一个随时可调用且不随页面渲染的全局组件。
需求分析
toa...
toast是常用的轻提示弹框,常用于页面loading和提示语弹窗。
本例基于react实现一个随时可调用且不随页面渲染的全局组件。
需求分析
- toast 不需要同页面一起被渲染,而是根据需要被随时调用。
- toast 是一个轻量级的提示组件,它的提示不会打断用户操作,并且会在提示的一段时间后自动关闭。
- toast 需要提供几种不同的消息类型以适应不同的使用场景。
- toast 的方法必须足够简洁,以避免不必要的代码冗余。
如何使用
首先引入
import toast from './components/toast'
jsx中事件调用:
<button onclick={() => { toast.info('普通提示') }}>普通提示</button>
js中方法调用:
toast.info('普通提示')
回调方法:
const hideloading = toast.loading('加载中...', 0, () => { toast.success('加载完成') }) settimeout(hideloading, 2000)
调用规则:
3个参数:
- content 提示内容 string(loading方法为可选)
- duration 提示持续时间 number,单位ms(可选)
- onclose 提示关闭时的回调函数(可选)
toast.info("普通",2000) toast.success("成功",1000,() => { console.log('回调方法') })) toast.error("错误") toast.loading()
代码实现
目录结构:
- index.js:对外export接口,设置默认的参数值,全局创建或销毁toast的div。
- toast.js:toast具体显示的内容及多次调用toast时的状态管理。
- toast.css:toast的样式,费话不多说。
index.js:
import react from 'react' import reactdom from 'react-dom' import toast from './toast' import './toast.css' function createnotification() { const div = document.createelement('div') document.body.appendchild(div) const notification = reactdom.render(<toast />, div) return { addnotice(notice) { return notification.addnotice(notice) }, destroy() { reactdom.unmountcomponentatnode(div) document.body.removechild(div) } } } let notification const notice = (type, content, duration = 2000, onclose) => { if (!notification) notification = createnotification() return notification.addnotice({ type, content, duration, onclose }) } export default { info(content, duration, onclose) { return notice('info', content, duration, onclose) }, success(content = '操作成功', duration, onclose) { return notice('success', content, duration, onclose) }, error(content, duration , onclose) { return notice('error', content, duration, onclose) }, loading(content = '加载中...', duration = 0, onclose) { return notice('loading', content, duration, onclose) } }
toast.js:
import react, { component } from 'react' class toastbox extends component { constructor() { super() this.transitiontime = 300 this.state = { notices: [] } this.removenotice = this.removenotice.bind(this) } getnoticekey() { const { notices } = this.state return `notice-${new date().gettime()}-${notices.length}` } addnotice(notice) { const { notices } = this.state notice.key = this.getnoticekey() // notices.push(notice);//展示所有的提示 notices[0] = notice;//仅展示最后一个提示 this.setstate({ notices }) if (notice.duration > 0) { settimeout(() => { this.removenotice(notice.key) }, notice.duration) } return () => { this.removenotice(notice.key) } } removenotice(key) { const { notices } = this.state this.setstate({ notices: notices.filter((notice) => { if (notice.key === key) { if (notice.onclose) settimeout(notice.onclose, this.transitiontime) return false } return true }) }) } render() { const { notices } = this.state const icons = { info: 'toast_info', success: 'toast_success', error: 'toast_error', loading: 'toast_loading' } return ( <div classname="toast"> { notices.map(notice => ( <div classname="toast_bg" key={notice.key}> <div classname='toast_box'> <div classname={`toast_icon ${icons[notice.type]}`}></div> <div classname='toast_text'>{notice.content}</div> </div> </div> )) } </div> ) } } export default toastbox
toast.css:
.toast { position: fixed; left: 0; top: 0; z-index: 999; display: flex; flex-direction: column; } .toast_bg { position: fixed; width: 100%; height: 100%; left: 0; top: 0; } .toast_box { position: relative; left: 50%; top: 50%; width: 2.8rem; height: 2rem; margin: -1rem -1.4rem; background: rgba(0, 0, 0, 0.65); border-radius: .1rem; color: #fff; } .toast_text { position: absolute; bottom: 16%; text-align: center; width: 90%; margin: 0 5%; height: .28rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } .toast_icon { position: relative; left: 50%; top: 15%; margin: -.4rem; width: .8rem; height: .8rem; } .toast_loading { -webkit-animation: loading 1s steps(12, end) infinite; animation: loading 1s steps(12, end) infinite; background: url("") no-repeat; background-size: 100%; } .toast_success { background: url("") no-repeat; background-size: 100%; } .toast_error { background: url("") no-repeat; background-size: 100%; } .toast_info { background: url("") no-repeat; background-size: 100%; } @-webkit-keyframes loading { 0% { -webkit-transform: rotate3d(0, 0, 1, 0deg); transform: rotate3d(0, 0, 1, 0deg); } 100% { -webkit-transform: rotate3d(0, 0, 1, 360deg); transform: rotate3d(0, 0, 1, 360deg); } } @keyframes loading { 0% { -webkit-transform: rotate3d(0, 0, 1, 0deg); transform: rotate3d(0, 0, 1, 0deg); } 100% { -webkit-transform: rotate3d(0, 0, 1, 360deg); transform: rotate3d(0, 0, 1, 360deg); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 电脑无法在线听歌有哪些解决方法
下一篇: AI制作漂亮的图案拼贴