背景
当一个 Vue.js 单页应用程序 (SPA) 部署到生产环境时,可能会遇到这样的问题:刷新页面时,浏览器会返回 404 错误。这是因为浏览器在刷新时会请求服务器对应的 URL,而服务器并没有相应的资源,因此返回了 404 错误。
这个问题是因为在 SPA 应用中,所有路由都是在前端通过 JavaScript 处理的,而不是由服务器直接返回对应的 HTML 文件。因此,刷新页面时浏览器会直接请求服务器对应的 URL,而服务器并不知道如何处理它。
在本文中,我们将介绍如何通过配置服务器和 Vue.js 应用,来解决这个问题。
解决方案
第一步:配置服务器
在服务器端,需要配置服务器以将所有非静态资源的请求都返回 index.html。这就是我们在 Vue.js 应用中使用的默认路由。例如,在 Apache 服务器上,可以使用 .htaccess
文件进行配置,如下所示:
<IfModule mod_rewrite.c> RewriteEngine On RewriteBase / RewriteRule ^index\.html$ - [L] RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /index.html [L] </IfModule>
这些规则将在请求的 URL 不是 index.html 且不是现有文件或目录时,重定向到 index.html
页面。
第二步:配置 Vue.js 应用
在我们的 Vue.js 应用中,需要添加一个路由模式。具体来说,我们需要使用 history
模式。 history
模式使用 HTML5 history
API 来管理路由状态,而不是使用哈希值(#
)作为 URL 的一部分。
可以通过在 Vue.js 路由配置中设置 mode: 'history'
来启用历史模式,如下所示:
-- -------------------- ---- ------- ------ --- ---- ------ ------ ------ ---- ------------- ------ ---- ---- ------------------------ ------ ----- ---- ------------------------- ---------------- ------ ------- --- -------- ----- ---------- ------- - - ----- ---- ----- ------- ---------- ----- -- - ----- --------- ----- -------- ---------- ------ -- -- ---
示例代码
在以下示例中,我们定义了两个路由:/
和 /about
。当用户在地址栏中输入 http://localhost:8080/
时,Vue.js 应用将路由到 Home
组件;当用户输入 http://localhost:8080/about
时,应用将路由到 About
组件。
-- -------------------- ---- ------- ---- ---------- --- --------- ----- ----- ---------- ------ ----- ---------------- ------------- ----------- ------- ------ ---- --------------- ------- ------------------------------ ------- -------
-- -------------------- ---- ------- -- --------- ------ --- ---- ------ ------ ------ ---- ------------- ------ ---- ---- ------------------------ ------ ----- ---- ------------------------- ---------------- ------ ------- --- -------- ----- ---------- ------- - - ----- ---- ----- ------- ---------- ----- -- - ----- --------- ----- -------- ---------- ------ -- -- --- -- ------- ------ --- ---- ------ ------ --- ---- ------------ ------ ------ ---- -------------- --- ----- --- ------- ------- ------- - -- ------- ---
结论
通过配置服务器和 Vue.js 应用程序的路由,我们可以解决刷新页面返回 404 错误的问题。在 Vue.js 应用中使用 history
模式,可以使 URL 更加干净、简洁,同时也可以带来更好的用户体验。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/67389364317fbffedf116b9c