Я создаю пакет Typescript, который должен работать как на переднем, так и на заднем концах. Я использую этот пакет, чтобы узнать, является ли среда браузером или узлом:
https://www.npmjs.com/package/browser-or-node
Точка входа - один файл index.js
Я могу создать и опубликовать приложение без проблем, однако, когда я импортирую его и пытаюсь запустить его в браузере, я получаю сообщение об ошибке
Module not found: Error: Can't resolve 'fs'
Похоже, это связано с тем, что я импортирую fs, который является методом узла, а браузер не знает, что делать.
Какова наилучшая практика в этом случае, чтобы избежать этой проблемы? Если я не импортирую этот модуль, библиотека будет работать нормально.
Мой пакет.json:
"license": "MIT",
"main": "dist/index.js",
"types": "dist/index.d.ts",
"scripts": {
"build": "tsc",
"test": "mocha -r ts-node/register src/**/*.spec.ts"
},
"devDependencies": {
"@types/chai": "^4.1.7",
"@types/mocha": "^5.2.6",
"@types/sinon": "^7.0.11",
"@types/sinon-chai": "^3.2.2",
"chai": "^4.2.0",
"mocha": "^6.1.4",
"sinon": "^7.3.2",
"sinon-chai": "^3.3.0",
"ts-node": "^8.1.0",
"typescript": "^3.4.4"
},
"dependencies": {
"@types/es6-promise": "^3.3.0",
"axios": "^0.18.0",
"browser-or-node": "^1.2.1",
"dotenv": "^7.0.0"
}
Мой tsconfig.json:
{
"compilerOptions": {
"target": "es5",
"module": "commonjs",
"declaration": true,
"outDir": "./dist",
"strict": true,
"noImplicitAny": false,
"lib": [ "es2015" ]
},
"exclude":[
"node_modules",
"./dist",
"./**/*.spec.ts",
"./test/**/*.ts"
]
}
Функция, вызывающая проблему:
import * as fs from 'fs';
export function saveTokensNode(data: any, path: string) {
try {
fs.writeFileSync(path, JSON.stringify(data))
} catch (err) {
console.error(err)
}
}
Где я его использую:
setCredentials(tokens) {
if (isBrowser) {
saveTokensStorage(tokens)
}
if (isNode) {
saveTokensNode(tokens, 'temp/tokensToStore.json')
}
}