Похоже, что в tsconfig.json не включен 'allowJs', потому что он экспортирует объявления.
Есть ли причина, по которой вы не хотите, чтобы это был машинописный файл? Если вы измените test.js на test.ts, сделав его .ts должен позволить его распознавать в файле индекса.
UPDATE
Полную историю чата, чтобы добраться до этой точки, можно найти здесь .
Репозиторий для проверки найден здесь
ОК, так что простое решение, о котором упоминает @ maaz-syed-adeeb, будет работать:
import { path } from './lib/test.js'
Причина, по которой расширение является важным, заключается в том, что файл определения имеет приоритет над файлом javascript в среде машинописного текста. Вот почему импорт модуля не работал.
Чтобы не указывать расширение .js
, вы также можете настроить структуру каталогов следующим образом:
src
|- index.ts
|- lib
|- test.js
|- test.d.ts
|- index.[js|ts]
в ./lib/index
файл экспортировать все из теста:
//./src/lib/index.[js|ts]
export * from './test'
и затем импортировать все из lib:
// ./src/index.ts
import { path } from './lib'
// or
import { path } from './lib/test.js'
Если вы используете смесь JavaScript и машинописного текста (скажем, вы переходите на машинописный текст с существующей кодовой базой), вам необходимо обновить tsconfig.json
, чтобы включить его, чтобы вы не получали предупреждения в своей IDE :
{
"compilerOptions": {
"allowJs": true,
"declaration": false
}
}
Это так, что ваши файлы JavaScript будут перенесены в каталог назначения вместе с файлами машинописи.