sveltekit 路由在部署到服务器时不起作用
来源:stackoverflow
时间:2024-04-18 14:27:33 335浏览 收藏
小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《sveltekit 路由在部署到服务器时不起作用》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
这是我的 svelte.config.js,我正在使用适配器静态:
const config = { kit: { adapter: adapter({ // default options are shown pages: '../backend/build', assets: '../backend/build', fallback: null, precompress: false, }), alias: {}, appdir: '_app', browser: { hydrate: true, router: true, }, files: { assets: 'static', hooks: 'src/hooks', lib: 'src/lib', params: 'src/params', routes: 'src/routes', serviceworker: 'src/service-worker', template: 'src/app.html', }, floc: false, methodoverride: { parameter: '_method', allowed: [], }, paths: { assets: '', base: '', }, trailingslash: 'always', vite: { server: { proxy: { '/api': 'http://localhost:5555', }, }, }, }, preprocess: null,};
从后端(go lang)我提供构建目录和index.html 文件。主页工作正常,但每当我单击任何路线时,它都会向服务器发送获取请求,而不是在应用程序本身中进行重定向。
这是从后端提供服务的 go 代码:
router := gin.default() router.staticfile("/", "./build/index.html") router.staticfs("/_app", http.dir("build/_app"))
我还尝试过以下代码:
router.NoRoute(func(c *gin.Context) { path := c.Request.URL.Path c.File("./build/index.html") })
注意:当我运行 npm run preview
时,一切正常。
正确答案
adapter-static 有两种不同的操作模式:SPA 和预渲染。当有多个路由时, npm run dev
和 npm run Preview
都会按预期工作,但是一旦构建,静态路由就会落入 Web 服务器(在您的情况下为 Go 框架),但任何其他静态服务器也会发生同样的情况(我还测试了 Nginx 和 Apache)。
我找到了一种避免将站点转换为 SPA 的解决方法:安装 url 重写机制作为中间件,以便添加静态服务器在编译站点中期望的 .html
扩展。就我而言,我使用了 Go Fiber github.com/go Fiber/rewrite/v2
并且它按预期工作(与使用 npm run dev
时的行为相同)
对于 Nginx 静态服务器,解决方案是相同的 url 重写,可以按照此处的说明使用:https://www.codesmite.com/article/clean-url-rewrites-using-nginx
好了,本文到此结束,带大家了解了《sveltekit 路由在部署到服务器时不起作用》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多Golang知识!
-
502 收藏
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
139 收藏
-
204 收藏
-
325 收藏
-
477 收藏
-
486 收藏
-
439 收藏
-
357 收藏
-
352 收藏
-
101 收藏
-
440 收藏
-
212 收藏
-
143 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习