如何在 Visual Studio 代码中导入扩展名和文件?

Rat*_*mar 10 javascript node.js visual-studio-code

使用nodejs进行开发运行(--experimental-modules)

当前的Visual Studio代码智能导入如下

从“./config”导入配置;

但需要如下

从“./config.js”导入配置;

没有 .js 会出现如下错误

internal/modules/esm/resolve.js:61
  let url = moduleWrapResolve(specifier, parentURL);
            ^

Error: Cannot find module C:\Uday\Projects\practice-server\config imported from C:\Uday\Projects\practice-server\index.js
    at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:61:13)
    at Loader.resolve (internal/modules/esm/loader.js:85:40)
    at Loader.getModuleJob (internal/modules/esm/loader.js:191:28)
    at ModuleWrap.<anonymous> (internal/modules/esm/module_job.js:42:40)
    at link (internal/modules/esm/module_job.js:41:36) {
  code: 'ERR_MODULE_NOT_FOUND'
}
Run Code Online (Sandbox Code Playgroud)

所以我需要 Visual Studio 代码智能来导入扩展?

//index.js
import express from "express";
import config from "./config.js";



const api_app = express();
const api_port = config.api_port
api_app.listen(api_port, () => {
    console.log(`Practice Server started on ${api_port}`);
});

//package.json
{
  "name": "practice-server",
  "type": "module",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "dependencies": {
    "express": "^4.17.1"
  }
}

//config.js
let config = function () { };

config.api_port = 6000;


export default config;
Run Code Online (Sandbox Code Playgroud)

Was*_*eem 16

在全局设置(或项目设置)中,添加以下配置:

  // Preferred path ending for auto imports.
  //  - auto: Use project settings to select a default.
  //  - minimal: Shorten `./component/index.js` to `./component`.
  //  - index: Shorten `./component/index.js` to `./component/index`
  //  - js: Do not shorten path endings; include the `.js` extension.

  "javascript.preferences.importModuleSpecifierEnding": "js",
Run Code Online (Sandbox Code Playgroud)

请注意,目前这仅适用于自动导入(即在引用另一个文件的导出时通过智能感知,VSCode 自动导入它)。手动输入导入语句时,它不能与自动建议一起使用。


Sum*_*ash 0

我总是这样使用我的 config.js 。也许它可以帮助你。

const config = require('./config');
Run Code Online (Sandbox Code Playgroud)

//现在从配置中访问值

const sys_dbconfig = config_data['sys_database'];
const user = configdata['system_admin_name'];
Run Code Online (Sandbox Code Playgroud)

这是我的 config.js

var config = {
"sys_database": {
    "user": 'postgres',
    "host": 'localhost',
    "database": 'postgres',
    "password": 'postgres',
    "port": "5432"
},
"system_admin_name": "system",
"url":"http://xxx.xx.x.xxx:3000/wscalc1?wsdl"
}

module.exports = config;
Run Code Online (Sandbox Code Playgroud)