Я постоянно получаю предупреждение Циклы Require разрешены, но могут привести к неинициализированным значениям. Рассмотрите возможность рефакторинга, чтобы исключить необходимость в цикле. на своем терминале, и это сильно усложняет отладку моей программы.
я использовал
YellowBox.ignoreWarnings([
'Require cycle:',
])
а также
console.disableYellowBox = true;
Но ни то, ни другое не сработало. YellowBox.ignoreWarnings работал только для предупреждений, отображаемых на мобильном телефоне, но не для предупреждений на терминале моей IDE. Как я могу предотвратить получение этих предупреждений на терминале.





Я закомментировал следующие строки, и они перестали появляться как в терминале, так и в устройстве.
node_modules/metro/src/lib/polyfills/require.js (строка 114)
console.warn( "Require cycle: ".concat(cycle.join(" -> "), "\n\n") + "Require cycles are allowed, but can result in uninitialized values. " + "Consider refactoring to remove the need for a cycle." );
После комментирования этого предупреждения перезапуск проекта устранил мои проблемы. PS. Я использую экспо.
Я закомментировал console.warn в node_modules/expo/build/environment/muteWarnings.fx.js строке 10.
console.warn = function warn(...args) {
// if (args.length > 0 &&
// typeof args[0] === 'string' &&
// (/^Require cycle: .*node_modules/.test(args[0]) ||
// /Use UIManager\.getViewManagerConfig\('LottieAnimationView'\) instead\./.test(args[0]) ||
// /ReactNative\.NativeModules\.LottieAnimationView\.getConstants/.test(args[0]))) {
// return;
// }
// originalWarn.apply(console, args);
};
Я пошел более безопасным путем :) Я использовал patch-package, чтобы убедиться, что я все еще вижу свои собственные ошибки... м-м-м... требуются циклы :)
метро+0.59.0.патч
diff --git a/node_modules/metro/.DS_Store b/node_modules/metro/.DS_Store
new file mode 100644
index 0000000..21ab2f3
Binary files /dev/null and b/node_modules/metro/.DS_Store differ
diff --git a/node_modules/metro/src/lib/polyfills/require.js b/node_modules/metro/src/lib/polyfills/require.js
index 8c04756..3b208f6 100644
--- a/node_modules/metro/src/lib/polyfills/require.js
+++ b/node_modules/metro/src/lib/polyfills/require.js
@@ -114,11 +114,14 @@ function metroRequire(moduleId) {
.map(id => (modules[id] ? modules[id].verboseName : "[unknown]")); // We want to show A -> B -> A:
cycle.push(cycle[0]);
- console.warn(
- `Require cycle: ${cycle.join(" -> ")}\n\n` +
+ const cycleString = cycle?.join(" -> ");
+ if (!(cycleString?.startsWith('node_modules/'))) {
+ console.warn(
+ `Require cycle: ${cycleString}\n\n` +
"Require cycles are allowed, but can result in uninitialized values. " +
"Consider refactoring to remove the need for a cycle."
- );
+ );
+ }
}
}
Мое решение этой проблемы, надеюсь, оно поможет другим:
import { AppRegistry, LogBox } from 'react-native';
import App from './App';
import { name as appName } from './app.json';
LogBox.ignoreLogs(['Require cycle:']);
AppRegistry.registerComponent(appName, () => App);
Ваш ответ может быть улучшен с помощью дополнительной вспомогательной информации. Пожалуйста, редактировать, чтобы добавить дополнительную информацию, например цитаты или документацию, чтобы другие могли подтвердить правильность вашего ответа. Дополнительную информацию о том, как писать хорошие ответы, можно найти в справочном центре.
Скрытие желтых ящиков - это не решение, это своего рода патч. Вы должны изучить свой код, на самом деле проблема будет заключаться в том, что ваши компоненты будут требовать друг друга. Например, вы делаете компонент A, который импортирует B, а в B вы импортируете A. Если вы покажите свои полные журналы, я сообщу вам точные компоненты.
их никак не скрыть, ни терминала IDEA, ни из системного AFAIK.
YellowBox.ignoreWarningsиconsole.disableYellowBoxдействуют только на устройства/симуляторы