本篇文章為大家展示了使用React怎么實現全局組件Toast輕提示效果,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
成都創新互聯成立與2013年,先為海門等服務建站,海門等地企業,進行企業商務咨詢服務。為海門企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。需求分析
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); } }
上述內容就是使用React怎么實現全局組件Toast輕提示效果,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注創新互聯行業資訊頻道。
分享標題:使用React怎么實現全局組件Toast輕提示效果-創新互聯
標題來源:http://vcdvsql.cn/article20/cdggco.html
成都網站建設公司_創新互聯,為您提供小程序開發、網站策劃、移動網站建設、自適應網站、網站內鏈、域名注冊
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯