为什么在使用 VSCode 时需要 jsconfig.js

发布时间:作者:

Why you need a jsconfig.js when using VSCode image

如果您想在使用 VSCode 开发 JavaScript 时提升开发体验,您需要开始在所有项目中添加 jsconfig.json 文件。

什么是 jsconfig.json?

VSCode 使用 jsconfig.json 文件来辅助您的 JavaScript 语言服务,从而显著提升您的开发体验。

假设您刚刚安装了一个新的 Laravel PHP 应用程序,并且正在使用 Laravel Breeze Inertia 启动套件。当您打开 webpack.config.js 文件时,您将看到以下内容。

const path = require('path');
 
 
module.exports = {
resolve: {
alias: {
'@': path.resolve('resources/js'),
},
},
};

上面的代码帮助 Webpack 指导您的应用程序如何 解析 模块。它允许您使用 @ 作为快捷方式,因此您无需后退来创建其他组件的相对路径。

假设您在 /resources/js/Components 中有一个名为 Input.vue 的组件,并在 /resources/js/Pages/Dashboard/Index.vue 中有一个页面组件。要导入 Input.vue 组件,它将如下所示。

import Input from `../../Components/Input.vue

借助 @ 别名,您可以将其更改为以下内容。

import Input from `@/Components/Input.vue

您可以更进一步,添加一个组件别名。

const path = require('path');
 
 
module.exports = {
resolve: {
alias: {
'@': path.resolve('resources/js'),
'@Components': path.resolve('resources/js'/Components),
},
},
};

这样您就可以像这样导入。

import Input from `@Components/Input.vue

这样干净多了。

如果您使用的是 VSCode,这里唯一缺少的是,您的 IDE 无法帮助您自动完成路径。这就是 jsconfig.json 文件发挥作用的地方。

让我们创建一个 jsconfig.json 文件,并将其放置在 Laravel 应用程序的根目录中,与 webpack.config.js 文件处于同一级别。打开它并添加以下内容。

{
"compilerOptions": {
"baseUrl": ".",
"paths": {
"@/*": [
"resources/js/*"
],
"@Components/*": [
"resources/js/Components/*"
]
}
},
"exclude": [
"node_modules",
"public"
]
}

请注意,您可能需要重新启动 VSCode 才能使 jsconfig.json 生效。

现在,当您键入 import Input from '@" 时,您将开始看到您的文件夹结构以及每个目录中的文件。

就是这样!现在您可以在 VSCode IDE 中获得完整的自动完成和文件浏览支持。

祝您编码愉快!

Yaz Jallad photo

Yaz 是一位全栈开发人员,他对 Laravel、Vue.js、Tailwind CSS 和 Inertia.js 的所有事物充满热情。

Cube

Laravel 新闻

加入 40,000 多名其他开发人员,绝不错过新技巧、教程等等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和对本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

无妥协

Joel 和 Aaron,来自 No Compromises 播客的两名经验丰富的开发者,现在可以为您的 Laravel 项目提供服务。 ⬧ 固定费用 7500 美元/月。 ⬧ 无冗长的销售流程。 ⬧ 无合同。 ⬧ 100% 退款保证。

无妥协
Kirschbaum logo

Kirschbaum

提供创新和稳定性,以确保您的 Web 应用程序取得成功。

Kirschbaum
Shift logo

Shift

正在运行旧版本的 Laravel?即时、自动化的 Laravel 升级和代码现代化,以保持您的应用程序更新。

Shift
Bacancy logo

Bacancy

只需 2500 美元/月,即可为您的项目配备一名具有 4-6 年经验的经验丰富的 Laravel 开发人员。获得 160 小时的专业知识和 15 天无风险试用。立即预约电话!

Bacancy
Lucky Media logo

Lucky Media

立即获得好运 - Laravel 开发的理想选择,拥有超过十年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar: Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的力量带到 Laravel。

Lunar: Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 工作板

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动套件

SaaSykit 是一个 Laravel SaaS 启动套件,包含运行现代 SaaS 所需的所有功能。支付、漂亮结账、管理面板、用户仪表板、身份验证、现成组件、统计、博客、文档等等。

SaaSykit:Laravel SaaS 启动套件
Rector logo

Rector

您无缝 Laravel 升级、降低成本和加速创新,以帮助成功公司。

Rector
MongoDB logo

MongoDB

通过 MongoDB 和 Laravel 的强大集成增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务性、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。了解灵活、现代的 MongoDB 数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在您的 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 包在您的 Laravel 应用程序中添加评论

阅读文章