Reactjs?錯(cuò)誤邊界優(yōu)雅處理方法demo
正文
每當(dāng)你的react應(yīng)用在任何react功能或類(lèi)組件中遇到任何javascript錯(cuò)誤時(shí),都會(huì)破壞整個(gè)應(yīng)用,這對(duì)你的終端用戶來(lái)說(shuō)是一種糟糕的體驗(yàn)。React 16 引入了錯(cuò)誤邊界 ,以擺脫你的應(yīng)用程序中的這種糟糕體驗(yàn)。有了錯(cuò)誤邊界 ,你現(xiàn)在可以優(yōu)雅地處理并讓用戶知道,每當(dāng)你的應(yīng)用程序遇到錯(cuò)誤時(shí),就會(huì)出現(xiàn)問(wèn)題。
在這篇文章中,我們將學(xué)習(xí)如何通過(guò)實(shí)現(xiàn)錯(cuò)誤邊界來(lái)處理這些錯(cuò)誤 ,并看看它們的作用。
首先,在vs code或任何其他IDE中創(chuàng)建一個(gè)新的react應(yīng)用程序,我個(gè)人更喜歡VS Code。
什么是錯(cuò)誤邊界?
錯(cuò)誤邊界也是反應(yīng)組件,它可以幫助你捕捉被錯(cuò)誤邊界包裹的組件中的錯(cuò)誤,并顯示一個(gè)回退 UI(當(dāng)捕捉到錯(cuò)誤時(shí)顯示的UI,而不是崩潰的應(yīng)用程序)。
錯(cuò)誤邊界可以捕捉
- 渲染錯(cuò)誤
- 生命周期錯(cuò)誤
- 構(gòu)造器錯(cuò)誤
錯(cuò)誤邊界不能捕捉
- 事件處理程序中的錯(cuò)誤
- 異步代碼中的錯(cuò)誤
- 服務(wù)器端渲染中的錯(cuò)誤
- 錯(cuò)誤邊界中的錯(cuò)誤 (Duhh!)
錯(cuò)誤邊界的實(shí)現(xiàn)
要使一個(gè)類(lèi)組件成為錯(cuò)誤邊界組件,你只需要定義**靜態(tài)的getDerivedStateFromError()和componentDidCatch()**生命周期方法。
讓我們創(chuàng)建一個(gè)新的類(lèi)組件并使其成為一個(gè)錯(cuò)誤邊界,讓我們滾動(dòng)
export default class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = { error: null, errorInfo: null };
}
componentDidCatch(error, errorInfo) {
// use lifecycle to catch errors in any components below and re-render fallback UI
this.setState({
error: error,
errorInfo: errorInfo,
});
}
render() {
if (this.state.errorInfo) {
// Fallback UI
return (
<div>
<h2>Something went wrong.</h2>
<details style={{ whiteSpace: "pre-wrap" }}>
{this.state.error && this.state.error.toString()}
<br />
{this.state.errorInfo.componentStack}
</details>
</div>
);
}
// without error render normally in happy flow
return this.props.children;
}
}
用錯(cuò)誤邊界包住組件
現(xiàn)在我們可以用錯(cuò)誤邊界來(lái)包裝我們的整個(gè)應(yīng)用程序,或者包裝我們的子組件,以便在特定的組件上顯示后退的用戶界面,讓我們看看這個(gè)動(dòng)作吧
// Wrapping child component <ErrorBoundary> <ComponentThatThrowsError /> </ErrorBoundary>
// Wrapping our entire application <ErrorBoundary> <App /> </ErrorBoundary>
拋出一個(gè)錯(cuò)誤
讓我們在useEffect中拋出一個(gè)錯(cuò)誤,看看我們的錯(cuò)誤邊界是否能抓住。
const ComponentThatThrowsError = () => {
const [counter, setCounter] = useState(0);
useEffect(() => {
if (counter === 5) {
throw new Error("Something went wrong");
}
}, [counter]);
return (
<div>
<p>Parent Component Counter</p>
<button
className="btn"
onClick={() => {
setCounter(counter + 1);
}}
>
{counter}
</button>
</div>
);
};
當(dāng)計(jì)數(shù)器的值等于5時(shí),我們就拋出了一個(gè)錯(cuò)誤。
晃動(dòng)你的叔叔

我們可以看到,一旦子組件的計(jì)數(shù)器達(dá)到5,應(yīng)用程序就會(huì)為該組件渲染回退的用戶界面,而當(dāng)主錯(cuò)誤邊界捕捉到一個(gè)錯(cuò)誤時(shí),它就會(huì)渲染出白色的屏幕,顯示出出錯(cuò)的情況。
總結(jié)
我們?cè)谶@一章中講了很多,我希望這對(duì)你來(lái)說(shuō)不算太多。你學(xué)到了如何創(chuàng)建錯(cuò)誤邊界,以及為什么和在哪里使用它們。它們?nèi)绾问鼓愕膽?yīng)用程序的體驗(yàn)更好。
以上就是Reactjs 錯(cuò)誤邊界優(yōu)雅處理方法demo的詳細(xì)內(nèi)容,更多關(guān)于Reactjs 錯(cuò)誤邊界的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
React Grid Layout基礎(chǔ)使用示例教程
React Grid Layout是一個(gè)用于在React應(yīng)用程序中創(chuàng)建可拖拽和可調(diào)整大小的網(wǎng)格布局的庫(kù),通過(guò)使用React Grid Layout,我們可以輕松地創(chuàng)建自適應(yīng)的網(wǎng)格布局,并實(shí)現(xiàn)拖拽和調(diào)整大小的功能,本文介紹了React Grid Layout的基礎(chǔ)使用方法,感興趣的朋友一起看看吧2024-02-02
React Fiber結(jié)構(gòu)的創(chuàng)建步驟
這篇文章主要介紹了React Fiber結(jié)構(gòu)的創(chuàng)建步驟,幫助大家更好的理解和學(xué)習(xí)使用React,感興趣的朋友可以了解下2021-04-04
React項(xiàng)目中decorators裝飾器報(bào)錯(cuò)問(wèn)題解決方案
這篇文章主要介紹了React項(xiàng)目中decorators裝飾器報(bào)錯(cuò),本文給大家分享問(wèn)題所在原因及解決方案,通過(guò)圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
React?Fiber構(gòu)建completeWork源碼解析
這篇文章主要為大家介紹了React?Fiber構(gòu)建completeWork源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02
使用 React hooks 實(shí)現(xiàn)類(lèi)所有生命周期
react 自 16.8 開(kāi)始,引入了 Hooks 概念,使得函數(shù)組件中也可以擁有自己的狀態(tài),并且可以模擬對(duì)應(yīng)的生命周期,這篇文章主要介紹了使用 React hooks 怎么實(shí)現(xiàn)類(lèi)里面的所有生命周期,需要的朋友可以參考下2023-02-02
用React-Native+Mobx做一個(gè)迷你水果商城APP(附源碼)
這篇文章主要介紹了用React-Native+Mobx做一個(gè)迷你水果商城APP,功能需要的朋友可以參考下2017-12-12
React?Refs?的使用forwardRef?源碼示例解析
這篇文章主要為大家介紹了React?之?Refs?的使用和?forwardRef?的源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11

