نحن نبحث في استخدام Sentry مع React.
هذه المقالة جزء من سلسلة تبدأ برسالة خطأ ترقب باستخدام مثال: الجزء 1 .
رد فعل التنفيذ
نحتاج أولاً إلى إضافة مشروع Sentry جديد لهذا التطبيق ؛ من موقع Sentry. في هذه الحالة ، نختار React.
سنعيد تنفيذ زرينا ، Hello و Error ، في تطبيق React. نبدأ بإنشاء تطبيق المبتدئين الخاص بنا:
npx create-react-app react-app
ثم نقوم باستيراد حزمة Sentry:
yarn add @sentry/browser
وتهيئته:
React-app / src / index.js
...
import * as Sentry from '@sentry/browser';
const RELEASE = '0.1.0';
if (process.env.NODE_ENV === 'production') {
Sentry.init({
dsn: 'https://303c04eac89844b5bfc908ceffc6757c@sentry.io/1289887',
release: RELEASE,
});
}
...
ملاحظات:
- أثناء التطوير ، لدينا آليات أخرى لمراقبة المشكلات ، مثل وحدة التحكم ، لذلك نقوم فقط بتمكين Sentry لبناء الإنتاج
ثم نقوم بتنفيذ زري Hello و Error ونضيفهم إلى التطبيق:
React-app / src / Hello.js
import React, { Component } from 'react';
import * as Sentry from '@sentry/browser';
export default class Hello extends Component {
state = {
text: '',
};
render() {
const { text } = this.state;
return (
<div>
<button
onClick={this.handleClick}
>
Hello
</button>
<div>{text}</div>
</div>
)
}
handleClick = () => {
this.setState({
text: 'Hello World',
});
try {
throw new Error('Caught');
} catch (err) {
if (process.env.NODE_ENV !== 'production') {
return;
}
Sentry.captureException(err);
}
}
}
response-app / src / MyError.js
import React, { Component } from 'react';
export default class MyError extends Component {
render() {
return (
<div>
<button
onClick={this.handleClick}
>
Error
</button>
</div>
)
}
handleClick = () => {
throw new Error('Uncaught');
}
}
React-app / src / App.js
...
import Hello from './Hello';
import MyError from './MyError';
class App extends Component {
render() {
return (
<div className="App">
...
<Hello />
<MyError />
</div>
);
}
}
export default App;
المشكلة (خرائط المصدر)
يمكننا اختبار Sentry من خلال تجميع إنتاج عن طريق إدخال:
yarn build
ومن مجلد البناء أدخل:
npx http-server -c-1
المشكلة التي سنواجهها على الفور هي أن إدخالات خطأ الحارس تشير إلى أرقام الأسطر في الحزمة المصغرة ؛ غير مفيد للغاية.
Sentry , . localhost ( Sentry).
( )
-. , GitHub Pages (). :
build docs .
GitHub Pages ( GitHub), docs master
GitHub
: , , create-create-app . package.json:
"homepage": "https://larkintuckerllc.github.io/hello-sentry/"
:
https://larkintuckerllc.github.io/hello-sentry/
Hello.
, :
:
- , BRAVO.
, Error.
, :
()
JavaScript . React, React 16 " ".
– React, JavaScript , , . , .
…
. React 16, , - , React.
— Dan Abramov — Error Handling in React 16
, , , , , (, , ). , Error; .
, .
react-app / src / MyRenderError
import React, { Component } from 'react';
export default class MyRenderError extends Component {
state = {
flag: false,
};
render() {
const { flag } = this.state;
return (
<div>
<button
onClick={this.handleClick}
>
Render Error
</button>
{ flag && <div>{flag.busted.bogus}</div> }
</div>
)
}
handleClick = () => {
this.setState({
flag: true,
});
}
}
:
, React flag.busted.bogus,
( componentDidCatch); , , , :
react-app / src / ErrorBoundary.js
import React, { Component } from 'react';
import * as Sentry from '@sentry/browser';
export default class ErrorBoundary extends Component {
constructor(props) {
super(props);
this.state = { hasError: false };
}
componentDidCatch(err, info) {
this.setState({ hasError: true });
Sentry.captureException(err);
}
render() {
if (this.state.hasError) {
return <h1>Something went wrong.</h1>;
}
return this.props.children;
}
}
, :
react-app / src / App.js
...
import MyRenderError from './MyRenderError';
class App extends Component {
render() {
return (
<ErrorBoundary>
<div className="App">
...
</div>
</ErrorBoundary>
);
}
}
...
Render Error Sentry.
, .
P.S. Sentry https://t.me/sentry_ru