vue history模式下打包后本地无法访问除首页外的其他页面

本地直接运行无法打开除首页外的其他页面,这个是正常的,因为还需要在服务器端做配置,来看看vue router 官网怎么说:

官方说明

服务器配置示例

注意:以下示例假定你正在从根目录提供服务。如果你部署到子目录,你应该使用Vue CLI 的 publicPath 配置和相关的路由器的 base 属性。你还需要调整下面的例子,以使用子目录而不是根目录(例如,将RewriteBase/ 替换为 RewriteBase/name-of-your-subfolder/)。

#Apache
<IfModule mod_negotiation.c>
  Options -MultiViews
</IfModule>

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /index.html [L]
</IfModule>

也可以使用 FallbackResource 代替 mod_rewrite

#nginx
location / {
  try_files $uri $uri/ /index.html;
}
#原生 Node.js
const http = require('http')
const fs = require('fs')
const httpPort = 80

http
  .createServer((req, res) => {
    fs.readFile('index.html', 'utf-8', (err, content) => {
      if (err) {
        console.log('We cannot open "index.html" file.')
      }

      res.writeHead(200, {
        'Content-Type': 'text/html; charset=utf-8',
      })

      res.end(content)
    })
  })
  .listen(httpPort, () => {
    console.log('Server listening on: http://localhost:%s', httpPort)
  })
#Express + Node.js

对于 Node.js/Express,可以考虑使用 connect-history-api-fallback 中间件

附加说明

这有一个注意事项。你的服务器将不再报告 404 错误,因为现在所有未找到的路径都会显示你的 index.html 文件。为了解决这个问题,你应该在你的 Vue 应用程序中实现一个万能的路由来显示 404 页面。

const router = createRouter({
  history: createWebHistory(),
  routes: [{ path: '/:pathMatch(.*)', component: NotFoundComponent }],
})

另外,如果你使用的是 Node.js 服务器,你可以通过在服务器端使用路由器来匹配传入的 URL,如果没有匹配到路由,则用 404 来响应,从而实现回退。查看 Vue 服务器端渲染文档了解更多信息。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果使用 Vuehistory 模式,直接访问页面时可能会出现 404 错误。这是因为在 history 模式下,路由的 URL 是由浏览器处理的,而不是由服务器处理的。 要解决这个问题,可以在服务器上配置一个重定向规则,将所有的路由都重定向到 index.html 页面。这样,当用户访问不存在的页面时,服务器会将请求重定向到 index.html,然后 Vue 路由会接管处理该请求并显示正确的页面。 具体地,如果您使用的是 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> ``` 如果您使用的是 Nginx 服务器,可以在配置文件中添加以下规则: ``` location / { try_files $uri $uri/ /index.html; } ``` 这些规则会将所有的请求都重定向到 index.html 页面,并且只有当请求的文件不存在时才会这样做。这样,即使用户直接访问不存在的页面,也可以正确地显示您的 Vue 应用程序。 ### 回答2: Vuehistory模式前端路由模式之一,它使用浏览器的history API来管理路由状态。当使用history模式时,页面的URL并不包含#符号,而是以常规的URL形式展示。 当使用Vuehistory模式时,直接访问页面会出现404错误。这是因为在history模式下,由于服务端并没有相应的路由配置,所以无法正确地匹配到对应的页面。 要解决这个问题,我们需要在服务端进行一些配置。以下是一种常见的解决方案: 1. 配置服务端路由:在服务器上,我们需要配置通配符,将所有路径的请求都指向index.html。这样,当用户直接访问页面时,服务器会将请求指向Vue的入口文件,然后再由前端的路由来处理。 2. 修改nginx配置:如果我们使用了Nginx作为服务器,我们需要在nginx.conf文件中添加以下配置: ```nginx location / { try_files $uri $uri/ /index.html; } ``` 这里的配置会将所有URL请求都指向index.html。 3. 配置Apache服务器:如果我们使用Apache服务器,我们需要修改.htaccess文件,并将以下代码添加到文件末尾: ```apache <IfModule mod_rewrite.c> RewriteEngine On RewriteBase / RewriteRule ^index\.html$ - [L] RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule . /index.html [L] </IfModule> ``` 以上的配置会将所有非存在的文件和目录请求都指向index.html。 通过以上配置,当用户直接访问页面时,服务器会将请求指向Vue的入口文件index.html,然后再由前端的路由来处理,从而避免了404错误的出现。 ### 回答3: Vuehistory模式是指在使用Vue Router进行路由管理时,URL中不会出现"#",而是使用真实的URL路径。当使用history模式时,直接访问页面会导致404错误,主要是因为服务器没有正确配置。 要解决这个问题,首先需要在服务器上进行一些配置。具体步骤如下: 1. 配置后端服务器:在后端服务器上(如Nginx、Apache)添加一个rewrite规则,将所有路径都重定向到首页的入口文件。对于Nginx服务器,可以在配置文件中添加以下代码: ```nginx location / { try_files $uri $uri/ /index.html; } ``` 2. 在Vue项目的config目录下找到index.js文件,修改build.assetsPublicPath属性为'/',如下所示: ```javascript build: { assetsPublicPath: '/', } ``` 完成上述步骤后,重新部署项目,再尝试直接访问页面,应该可以正常显示,不再出现404错误。 需要注意的是,history模式需要服务器的支持,如果使用的是纯静态服务器(如GitHub Pages),无法进行服务器配置,那么直接访问页面可能依然会出现404错误。在这种情况下,可以考虑使用hash模式,即在URL中带有"#",这种模式下即使直接访问页面也可以正常显示。但需要注意的是,hash模式的URL可能不够美观,可以根据实际需求进行选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值