Чтобы добавить перевод, откройте Pull Request по этой ссылке.
Отображается содержимое для языка по умолчанию.
import {} from "effector/compat";
The library provides a separate module with compatibility up to IE11 and Chrome 47 (browser for Smart TV devices).
Since third-party libraries can import effector
directly, you should not use transpilers like Babel to replace effector
with effector/compat
in your code because by default, Babel will not transform third-party code.
Use a bundler instead, as it will replace effector
with effector/compat
in all modules, including those from third parties.
Required Polyfills
You need to install polyfills for these objects:
Promise
Object.assign
Array.prototype.flat
Map
Set
In most cases, a bundler can automatically add polyfills.
Vite
Vite Configuration Example
import { defineConfig } from "vite";
import legacy from "@vitejs/plugin-legacy";
export default defineConfig({
plugins: [
legacy({
polyfills: ["es.promise", "es.object.assign", "es.array.flat", "es.map", "es.set"],
}),
],
});
Usage
Manual Replacement
You can use effector/compat
instead of the effector
package if you need to support old browsers.
- import {createStore} from 'effector'
+ import {createStore} from 'effector/compat'
Automatic Replacement
However, you can set up your bundler to automatically replace effector
with effector/compat
in your code.
Webpack
Webpack Configuration Example
module.exports = {
resolve: {
alias: {
effector: "effector/compat",
},
},
};
Vite
Vite Configuration Example
import { defineConfig } from "vite";
export default defineConfig({
resolve: {
alias: {
effector: "effector/compat",
},
},
});
Документация на английском языке - самая актуальная, поскольку её пишет и обновляет команда effector. Перевод документации на другие языки осуществляется сообществом по мере наличия сил и желания.
Помните, что переведенные статьи могут быть неактуальными, поэтому для получения наиболее точной и актуальной информации рекомендуем использовать оригинальную англоязычную версию документации.