I18nManager.forceRTL 不会在首次应用加载时应用更改 [英] I18nManager.forceRTL doesn't applies changes in first app load
问题描述
我有一个由很棒的 React-native
创建的应用程序,我的布局设计为处于 RTL 模式.我已经设置了一个选项来强制布局为 RTL,但我的选项在安装后的第一个应用程序加载中不起作用.此功能适用于第二次运行.
I have an app that created by awesome React-native
and my layout designed to be in RTL mode. I've set up an option for forcing the layout to be RTL but my option doesn't works in first app load after installing. This feature applies in second run.
我在 index.js 中写了这个选项:
I wrote this option in our index.js:
import React, { Component } from 'react';
import { I18nManager } from 'react-native';
import { Provider } from 'react-redux';
I18nManager.forceRTL(true);
class App extends Component {
render() {
return (
<Provider store={store}>
<PersistGate loading={null} persistor={persistor}>
<MainStack />
</PersistGate>
</Provider>
);
}
}
export default App;
推荐答案
一周后,我终于找到了一种逻辑方法来使用 Redux
& 来解决这个问题.react-native-restart
插件.我还使用了一个漂亮的启动画面,用户不会为此目的显示重启进度.
After a week finally i found a logicly way to solve this issue with using Redux
& react-native-restart
plugin. I'm also use a nice splash screen to user don't show a restarting progress for this purpose.
那么让我们深入研究代码:
So let's dive into code:
Redux 操作:
export const GET_APP_LAYOUT_DIRECTION = 'GET_APP_LAYOUT_DIRECTION';
export const SET_APP_LAYOUT_DIRECTION = 'SET_APP_LAYOUT_DIRECTION';
export const getAppLayoutDirection = () => ({
type: GET_APP_LAYOUT_DIRECTION,
});
export const setAppLayoutDirection = direction => ({
type: SET_APP_LAYOUT_DIRECTION,
direction
});
Redux 减速器:
import {
GET_APP_LAYOUT_DIRECTION,
SET_APP_LAYOUT_DIRECTION,
} from '../actions/app';
const initialState = {
layout: 'ltr',
};
const reducer = (state = initialState, action) => {
switch (action.type) {
case GET_APP_LAYOUT_DIRECTION:
return {
...state,
};
case SET_APP_LAYOUT_DIRECTION:
return {
...state,
layout: action.direction,
};
default:
return state;
}
};
export default reducer;
主屏幕:
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import RNRestart from 'react-native-restart'; // Import package from node modules
import { getAppLayoutDirection, setAppLayoutDirection } from '../actions/app';
class Home extends PureComponent {
constructor(props) {
super(props);
this.props.dispatch(getAppLayoutDirection());
if(this.props.layout === 'ltr'){
this.props.dispatch(setAppLayoutDirection('rtl'));
RNRestart.Restart();
}
}
componentDidMount() {
if(this.props.layout && this.props.layout === 'rtl'){
SplashScreen.hide();
}
}
}
const mapStateToProps = (state) => {
const { layout } = state.app;
return {
layout
};
}
export default connect(mapStateToProps)(Home);
这篇关于I18nManager.forceRTL 不会在首次应用加载时应用更改的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!