单页应用这个概念,是随着前几年 AngularJS
、React
、Ember
等这些框架的出现而出现的。在前面的前言内容里,我们在页面渲染中讲了页面的局部刷新,而单页应用则是使用了页面的局部刷新的能力,在切换页面的时候刷新页面内容,从而获取更好的体验。
单页应用(SinglePage Web Application
,简称 SPA)和多页应用(MultiPage Application
,简称 MPA)的区别如下:
标题 | SPA | MPA |
---|---|---|
组成 | 一个主页面 + 多个页面片段 | 多个完整页面 |
资源共用(css,js) | 共用的资源只需要加载一次 | 每个页面都需要加载公用的资源 |
url 模式 | xxx/#/page1 xxx/#/page2 | xxx/page1.html xxx/page2.html |
刷新方式 | 页面局部刷新或更改 | 整页刷新 |
页面跳转 | 外壳不变,更新局部页面内容,容易实现跳转动画 | 从一个页面跳转到另一个页面,无法实现跳转动画 |
用户体验 | 页面片段间切换快,用户体验好 | 页面切换需要重新加载,比较慢且流畅度低,用户体验较差 |
数据传递 | 同一个页面,全局变量等很容易实现 | 依赖 url 传参、或者 cookie 、localStorage 等,实现麻烦 |
搜索引擎优化(SEO) | 实现较为困难,不利于 SEO 检索 | 实现方法简单 |
适用场景 | 对体验要求高的应用 | 需要对搜索引擎友好的应用 |
第一步:
我们在public
文件下建一个主页面 建一个副页面,目录结构如下
第二步:
有了主页面和副页面就要有对应的主页面的入口文件和副页面的入口文件,目录结构如下
第三步:
vue.config.js
中配置pages
,可以理解为多页面的配置映射。
pages: { index: { entry: 'src/main.js', template: 'public/index.html', filename: 'index.html', }, bangban: { entry: 'src/banban.js', template: 'bangban.html', filename: 'public/bangban.html' } }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理