中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用React怎么實現全局組件Toast輕提示效果

發布時間:2021-06-04 17:27:08 來源:億速云 閱讀:720 作者:Leah 欄目:web開發

本篇文章為大家展示了使用React怎么實現全局組件Toast輕提示效果,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

需求分析

  • 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()

代碼實現

目錄結構:

使用React怎么實現全局組件Toast輕提示效果

  1. index.js:對外export接口,設置默認的參數值,全局創建或銷毀Toast的DIV。

  2. toast.js:Toast具體顯示的內容及多次調用Toast時的狀態管理。

  3. 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輕提示效果,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

寻甸| 沭阳县| 徐闻县| 辰溪县| 武宣县| 临沂市| 精河县| 柯坪县| 镇坪县| 盐源县| 民丰县| 雷波县| 广饶县| 汽车| 中超| 密山市| 开封县| 临泽县| 冷水江市| 永州市| 西青区| 高州市| 金湖县| 桑日县| 灌云县| 汉寿县| 博乐市| 辽源市| 姜堰市| 舟山市| 肥东县| 仙桃市| 济宁市| 边坝县| 色达县| 东兴市| 鹿泉市| 屯留县| 南木林县| 浪卡子县| 电白县|