지속적인 배포로 @loadable/component 반응
여기에 예 ⤵
data:image/s3,"s3://crabby-images/40487/404874665f408908bba002bc4697e9fea7531678" alt=""
탐색하는 동안 브라우저는 새 버전으로 대체되어 더 이상 사용할 수 없는 정적 파일을 가져오는 것을 목표로 합니다.
웹 사이트가 더 이상 작동하지 않고 무엇을 해야 하는지 알려주지 않기 때문에 사용자 불만을 야기합니다.
data:image/s3,"s3://crabby-images/239aa/239aacb73c28140f97750a5e592b5b2a7ae2f245" alt=""
링크드인 솔루션
최근에 LinkedIn을 사용하셨다면 다음 화면을 보셨을 것입니다.
data:image/s3,"s3://crabby-images/c4a57/c4a5763b87244a19d47e757d8ce0e2cf2eb4eb9d" alt=""
그리고 그것이 제가 같은 문제에 적용한 솔루션입니다.
솔루션 적용
내부 구성 요소 오류를 처리하는
ErrorBoundary
구성 요소를 생성하고 사용자에게 새로 고침을 요청하십시오.import React from 'react';
class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = {
error: null,
errorInfo: null,
};
}
componentDidCatch(error, errorInfo) {
this.setState({
error,
errorInfo,
})
// You can also log error messages to an error reporting service here
}
render() {
if (this.state.errorInfo) {
// Error path
return (
<div className="error-boundary">
<h2>Something went wrong 😖</h2>
<button onClick={() => window.location.reload()}>Reload Application</button>
</div>
);
}
// Normally, just render children
return this.props.children;
}
}
export default ErrorBoundary;
그런 다음
<Router>...</Router>
을 다음과 같이 ErrorBoundary
구성 요소로 래핑합니다.function App() {
return (
<ErrorBoundary>
<Router>
...
</Router>
</ErrorBoundary>
);
}
그런 다음 예제 솔루션은 다음과 같습니다.
data:image/s3,"s3://crabby-images/0e97c/0e97cabb0d7cd49e8c0688dcb598ef19aea63834" alt=""
소스 코드
data:image/s3,"s3://crabby-images/29103/29103578eedb1ead1f8fde4a2a8f2e73798f485c" alt=""
https://github.com/aleixmorgadas/react-loadable-component-with-continuous-deployment의 소스 코드
⚡️ 피드백 환영
!(•̀ᴗ•́)و ̑̑
⚡️data:image/s3,"s3://crabby-images/b88a4/b88a420b016a1177c77debfffd25ca1576d3e351" alt=""
Reference
이 문제에 관하여(지속적인 배포로 @loadable/component 반응), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/aleixmorgadas/react-loadable-component-with-continuous-deployment-5ep3텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)