Mit der kontinuierlichen Weiterentwicklung der Frontend-Technologie werden auch Frontend-Frameworks ständig verbessert und optimiert. Eines der beliebtesten Frontend-Frameworks ist derzeit Vue. Es ist leichtgewichtig, einfach zu erlernen und zu verwenden und wird von der Mehrheit der Entwickler bevorzugt. Bei der Verwendung von Vue stießen einige Entwickler jedoch auf ein Problem: Nach dem Packen verschwand der Schnittstellenpfad (API). Was ist also das Problem?
Während des Entwicklungsprozesses verwenden wir den Schnittstellenpfad, wie zum Beispiel:
const url = '/api/user/login';
Nachdem wir das Vue-Projekt gepackt haben, wird es Möglicherweise werden Sie feststellen, dass der Schnittstellenpfad (API) verschwindet, z. B.:
const url = 'user/login';
Dies führt dazu, dass die Anforderungsschnittstelle fehlschlägt.
Der Grund für dieses Problem ist, dass Vue Webpack zum Verpacken verwendet und die Verpackungsmethode von Webpack darin besteht, alle Ressourcen, einschließlich JS, CSS, zu verpacken und zu komprimieren. Bilder usw.
Wir können einen Blick auf die Konfigurationsdatei vue.config.js
im Vue-Projekt werfen: vue.config.js
配置文件:
module.exports = { // 配置打包和部署的根路径 publicPath: process.env.NODE_ENV === 'production' ? './' : '/', // 打包时不生成.map文件,加快打包速度 productionSourceMap: false };
其中,publicPath
是我们在打包之后使用的路径。在开发环境下,我们使用的是/
,表示根路径;而在生产环境下,我们使用的是./
,表示相对路径。
由于我们的接口路径(api)是绝对路径,因此在打包时,接口路径(api)就会被打包成相对路径。这样就导致了接口路径(api)消失的问题。
针对这个问题,我们可以采用以下几种方法进行解决。
我们可以将接口路径(api)改为绝对路径,即添加域名前缀,如:
const url = 'http://localhost:8080/api/user/login';
这样,在打包时,接口路径(api)就不会被打包成相对路径了。
我们可以在vue.config.js
module.exports = { devServer: { proxy: { '/api': { target: 'http://localhost:3000', // 目标地址 changeOrigin: true, // 是否改变原始地址 secure: true, // 是否使用https pathRewrite: { '^/api': '' // 路径重写 } } } } };
publicPath
Dies ist der Pfad, den wir nach dem Packen verwenden. In der Entwicklungsumgebung verwenden wir /
, um den Stammpfad darzustellen; in der Produktionsumgebung verwenden wir ./
, um den relativen Pfad darzustellen. Da unser Schnittstellenpfad (API) ein absoluter Pfad ist, wird der Schnittstellenpfad (API) beim Packen in einen relativen Pfad gepackt. Dies führt dazu, dass das Problem des Schnittstellenpfads (API) verschwindet. LösungUm dieses Problem anzugehen, können wir die folgenden Methoden verwenden, um es zu lösen. Methode 1: Absoluten Pfad verwenden Wir können den Schnittstellenpfad (API) in einen absoluten Pfad ändern, dh das Domänennamenpräfix hinzufügen, z. B.: #🎜 🎜#const url = '/api/user/login';
vue.config.js
hinzufügen und den Schnittstellenpfad (API) weiterleiten ) zur Zieladresse. In der Entwicklungsumgebung verwenden wir einen Entwicklungsserver, der selbst ein Proxyserver ist. Wir können diesen Proxyserver für die Weiterleitung verwenden. #🎜🎜#rrreee#🎜🎜#Nach der Konfiguration des Proxys müssen wir beim Anfordern der Schnittstelle im Code nur den relativen Pfad schreiben, z. B.: #🎜🎜#rrreee#🎜🎜#Auf diese Weise nach dem Packen , der Schnittstellenpfad (API) Es wird nicht verschwinden. #🎜🎜##🎜🎜#Methode 3: Verwenden Sie vue-cli-plugin-apimock#🎜🎜##🎜🎜#Wir können das Plug-in vue-cli-plugin-apimock zum Interface-Mocking verwenden. Dieses Plug-in ermöglicht es uns, den Schnittstellenpfad (API) während der Entwicklungsphase mit Scheindaten zu verwenden und dann während des Packens den Schnittstellenpfad (API) durch die echte Schnittstellenadresse zu ersetzen. Dadurch kann nicht nur die Entwicklungseffizienz sichergestellt, sondern auch das Problem des Verschwindens des Schnittstellenpfads (API) vermieden werden. #🎜🎜##🎜🎜#Zusammenfassung#🎜🎜##🎜🎜#Anhand der obigen Analyse können wir erkennen, dass das Problem des Verschwindens des Schnittstellenpfads (API) durch die Umwandlung des absoluten Pfads in einen relativen Pfad beim Packen verursacht wird. Um dieses Problem zu lösen, können wir absolute Pfade verwenden, Agenten konfigurieren oder das Plug-in vue-cli-plugin-apimock verwenden. Welche Methode wir wählen, hängt von unserer tatsächlichen Situation und unseren Bedürfnissen ab. #🎜🎜#Das obige ist der detaillierte Inhalt vonWas soll ich tun, wenn die Schnittstellenpfad-API fehlt, nachdem Vue gepackt wurde?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!