使用COS静态网站功能搭建前端单页应用
最近更新时间: 2024-10-17 17:10:00
什么是单页应用?
单页应用(single-page application,SPA)是一种网络应用程序或网站的模型,它通过动态重写当前页面与用户进行交互,而非传统的从服务器重新加载整个新页面。这种方法避免了页面之间切换打断用户体验,使应用程序更像一个桌面应用程序。在单页应用中,所有必要的代码(HTML、JavaScript 和 CSS)都通过单个页面的加载而检索,或者根据需要(通常是为响应用户操作)动态装载适当的资源并添加到页面。
目前在前端开发领域,常见的单页应用开发框架有 React、Vue、Angular 等。
本文将使用目前较为热门的2个框架,一步步教您使用对象存储(Cloud Object Storage,COS)提供的静态网站功能快速搭建一个线上可用的单页应用,并提供一些常见问题的解决方案。
准备工作
编写前端代码
注意:
如果已经自行实现了代码,可直接跳至 开启存储桶静态网站配置 步骤查看。
使用 Vue 快速搭建一个单页应用
- 执行如下命令,安装 vue-cli:
npm install -g @vue/cli
- 执行如下命令,使用 vue-cli 快速生成一个 vue 项目,可参见 官方文档。
vue create vue-spa
- 执行如下命令,在项目根目录下安装 vue-router:
npm install vue-router -S (Vue2.x)
或者
npm install vue-router@4 -S (Vue3.x)
修改项目里的 main.js 和 App.vue 文件。
main.js 如下图:
App.vue 主要修改组件的 template,如下图:
说明:
由于篇幅有限,这里仅节选部分关键代码,完整代码可 单击此处 下载。
- 修改代码后,执行如下命令,进行本地预览。
npm run serve
- 调试并预览检查无误后,执行如下命令,打包生产环境代码。
npm run build
此时,将会在项目根目录下生成 dist 目录。至此,Vue 的程序代码已经准备完毕。
使用 React 快速搭建一个单页应用
- 执行如下命令,安装 create-react-app:
npm install -g create-react-app
使用 create-react-app 快速生成一个 react 项目,可参考 官方文档。
执行如下命令,在项目根目录下安装 react-router-dom:
npm install react-router-dom -S
修改项目里的 App.js 文件。
说明:
由于篇幅有限,这里仅节选部分关键代码,完整代码可 单击此处 下载。
- 修改代码后,执行如下命令,进行本地预览。
npm run start
- 调试并预览检查无误后,执行如下命令,打包生产环境代码。
npm run build
此时将会在项目根目录下生成 build 目录。至此,React 的程序代码已经准备完毕。
开启存储桶静态网站配置
进入已创建存储桶的详情页面,并在左侧导航栏中,单击基础配置 > 静态网站。
在静态网站管理页面进行配置。操作详情请参见 设置静态网站。
部署至 COS
找到之前已经配置了静态网站的存储桶,进入文件列表页面。
将编译目录(Vue 默认为 dist 目录,react 默认为 build 目录)下的所有文件上传至存储桶的根目录下。操作详情请参见 上传对象。
访问存储桶的静态网站域名(如下图中的访问节点)。
即可看到已经部署完成的应用主页,这里以 Vue 应用举例。
- 尝试切换路由(Home、Foo、Bar),并刷新页面,验证是否符合预期(即在路由下刷新不会出现404报错)。
常见问题
我不想使用静态网站的默认域名怎么办?可以使用我自己的域名吗?
除了上面使用的默认静态网站域名,COS 还支持设置自定义源站域名。配置成功后即可使用自己想要的域名来访问应用。
部署好应用之后,切换路由能成功渲染,但页面一刷新就出现404报错,是什么原因?
原因可能是配置静态网站的时候,缺失配置或错误配置了错误文档导致,请再次回顾本文开头提供的标准配置截图,可以看到错误文档和索引文档均配置为 index.html 。
由于单页应用的特性,我们需要保证在任何情况下都要成功访问到应用入口(一般为 index.html),这样才能触发后续路由的一系列内部逻辑。
切换路由之后,页面能正常显示,但 HTTP 状态码依然为404,怎样才能正常返回200?
这里原因是配置静态网站的时候,缺少了配置错误文档响应码导致,可参考开头的配置截图,将其配置为200即可解决。
配置了错误文档之后,访问错误的路径还需要展示404的功能,应该如何处理?
这里推荐在前端代码里实现404逻辑,在路由配置最底部设置一个底层的匹配规则,当前面所有规则都匹配失败的时候则渲染一个404组件,组件内容可根据自行需求来设计实现。具体可参考本文提供的代码 demo 里的路由配置的最后一个配置。
访问页面出现 403 Access Denied 报错是什么原因?
原因可能是存储桶的权限设置了私有读写,可以修改为公有读私有写解决。