- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前从用户的浏览器获取区域设置。用户现在可以在其个人资料中设置他们的首选语言,该语言存储在数据库中。我想从数据库中获取此值并为 i18next
设置正确的区域设置。我在这里读到了一些有关自己的检测功能的内容:https://github.com/i18next/i18next-browser-languageDetector 。但我不完全确定这是否是正确的使用方法。我的 i18n.js 文件当前设置如下:
import i18n from 'i18next';
import Backend from 'i18next-xhr-backend';
import LanguageDetector from 'i18next-browser-languagedetector';
import { reactI18nextModule } from 'react-i18next';
import moment from 'moment';
export const i18nInit = (callback = () => { }) =>
// for easy overview use: https://devhints.io/moment its better than official docs:
moment.defineLocale('nl-custom', {
parentLocale: 'nl',
longDateFormat: {
LT: 'HH:mm',
LTS: 'HH:mm:ss',
L: 'D MMM', // need this format to display dates in past year(s)
LL: 'D MMMM YYYY', // need this format to display dates in the current year
LLL: 'YYYY-MM-DD HH:mm', // need this format as input for the date picker
LLLL: 'dddd D MMMM YYYY HH:mm',
},
}) &&
moment.defineLocale('en-custom', {
parentLocale: 'en',
longDateFormat: {
LT: 'HH:mm',
LTS: 'HH:mm:ss',
L: 'MMM D',
LL: 'MMMM D YYYY', // need this format to display dates in the current year
LLL: 'YYYY-MM-DD HH:mm', // need this format as input for the date picker
LLLL: 'MMMM dddd D YYYY HH:mm',
},
}) &&
i18n
// load translation using xhr -> see /public/locales
// learn more: https://github.com/i18next/i18next-xhr-backend
.use(Backend)
// detect user language
// learn more: https://github.com/i18next/i18next-browser-languageDetector
.use(LanguageDetector)
// pass the i18n instance to the react-i18next components.
// Alternative use the I18nextProvider: https://react.i18next.com/components/i18nextprovider
.use(reactI18nextModule)
// init i18next
// for all options read: https://www.i18next.com/overview/configuration-options
.init(
{
fallbackLng: 'en',
ns: ['actionpoints', 'common', 'menu', 'messages', 'overview', 'settings', 'shepherdTour', 'users', 'profile', 'meetingtypes'],
defaultNS: 'common',
whitelist: ['nl', 'en'],
backend: {
// Path where resources get loaded from, or a function
// returning a path:
// function(lngs, namespaces) { return customPath; }
// the returned path will interpolate lng, ns if provided like giving a static path
loadPath: '/locales/{{lng}}/{{ns}}.json',
},
load: 'currentOnly',
debug: false,
interpolation: {
escapeValue: false, // not needed for react as it escapes by default
},
// special options for react-i18next
// learn more: https://react.i18next.com/components/i18next-instance
react: {
wait: true,
},
},
callback
);
export default i18nInit();
是否可以在此处添加一个功能,从数据库中获取语言值,如果未设置,则会回退到浏览器的区域设置?
最佳答案
i18next-browser-languageDetector
检测用户的浏览器语言,它可能与数据库中存储的值不同。
您可以对服务器进行 Api 调用来获取用户语言,如果未设置,请使用 i18next-browser-languageDetector
作为后备。
所以代码应该是这样的
export const i18nInit = async (callback = () => { }) => {
const {lang} = await axios.get('/user-lang');
const i18nConfig = i18n
.use(Backend)
.use(reactI18nextModule);
if(!lang) {
i18nConfig.use(LanguageDetector);
}
i18nConfig.init({
lng: lang || undefined // if it has value, it will use this lang, if not, it is undefined as a default value of `lng`
...
});
}
如果你想要“花哨”,你可以编写一个自定义异步语言检测器,如下所示:
module.exports = exports = function(fallback){
return {
type: 'languageDetector',
async: true,
init: () => {},
detect: async function(callback){
try {
await axios.get('user-lang')
.then(language => {
if(language){
return callback(language)
}
return callback();
})
} catch(error){
callback();
}
},
cacheUserLanguage: function(language){
// ... cache users lang
}
}
};
关于reactjs - 从数据库而不是浏览器 i18next 获取语言环境,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59892851/
我的问题是如何在 python 中创建一个简单的数据库。我的例子是: User = { 'Name' : {'Firstname', 'Lastname'}, 'Address' : {'Street
我需要创建一个与远程数据库链接的应用程序! mysql 是最好的解决方案吗? Sqlite 是唯一的本地解决方案吗? 我使用下面的方法,我想知道它是否是最好的方法! NSString *evento
给定两台 MySQL 服务器,一台本地,一台远程。两者都有一个包含表 bohica 的数据库 foobar。本地服务器定义了用户 'myadmin'@'%' 和 'myadmin'@'localhos
我有以下灵活的搜索查询 Select {vt:code},{vt:productcode},{vw:code},{vw:productcode} from {abcd AS vt JOIN wxyz
好吧,我的电脑开始运行有点缓慢,所以我重置了 Windows,保留了我的文件。因为我的大脑还没有打开,所以我忘记事先备份我的 MySQL 数据库。我仍然拥有所有原始文件,因此我实际上仍然拥有数据库,但
如何将我的 Access 数据库 (.accdb) 转换为 SQLite 数据库 (.sqlite)? 请,任何帮助将不胜感激。 最佳答案 1)如果要转换 db 的结构,则应使用任何 DB 建模工具:
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
系统检查发现了一些问题: 警告:?:(mysql.W002)未为数据库连接“默认”设置 MySQL 严格模式 提示:MySQL 的严格模式通过将警告升级为错误来修复 MySQL 中的许多数据完整性问题
我想在相同的 phonegap 应用程序中使用 android 数据库。 更多说明: 我创建了 phonegap 应用程序,但 phonegap 应用程序不支持服务,所以我们已经在 java 中为 a
Time Tracker function clock() { var mytime = new Date(); var seconds
我需要在现有项目上实现一些事件的显示。我无法更改数据库结构。 在我的 Controller 中,我(从 ajax 请求)传递了一个时间戳,并且我需要显示之前的 8 个事件。因此,如果时间戳是(转换后)
我有一个可以收集和显示各种测量值的产品(不会详细介绍)。正如人们所期望的那样,显示部分是一个数据库+建立在其之上的网站(使用 Symfony)。 但是,我们可能还会创建一个 API 来向第三方公开数据
我们将 SQL Server 从 Azure VM 迁移到 Azure SQL 数据库。 Azure VM 为 DS2_V2、2 核、7GB RAM、最大 6400 IOPS Azure SQL 数据
我正在开发一个使用 MongoDB 数据库的程序,但我想问在通过 Java 执行 SQL 时是否可以使用内部数据库进行测试,例如 H2? 最佳答案 你可以尝试使用Testcontainers Test
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 已关闭 9 年前。 此问题似乎与 a specific programming problem, a sof
我正在尝试使用 MSI 身份验证(无需用户名和密码)从 Azure 机器学习服务连接 Azure SQL 数据库。 我正在尝试在 Azure 机器学习服务上建立机器学习模型,目的是我需要数据,这就是我
我在我的 MySQL 数据库中使用这个查询来查找 my_column 不为空的所有行: SELECT * FROM my_table WHERE my_column != ""; 不幸的是,许多行在
我有那个基地:http://sqlfiddle.com/#!2/e5a24/2这是 WordPress 默认模式的简写。我已经删除了该示例不需要的字段。 如您所见,我的结果是“类别 1”的两倍。我喜欢
我有一张这样的 table : mysql> select * from users; +--------+----------+------------+-----------+ | userid
我有表: CREATE TABLE IF NOT EXISTS `category` ( `id` int(11) NOT NULL, `name` varchar(255) NOT NULL
我是一名优秀的程序员,十分优秀!