由于公司想要把商城做由之前的php和前端混合开发改版为前后端分离,所以拿现在手上的vue项目来实践一下

https://github.com/chrisvfritz/prerender-spa-plugin

1.使用官方的vue-cli手脚搭建的项目跑prerender-spa-plugin一直报权限问题什么的

一个是由于路由写得有问题导致

另外一个是assetsPublicPath: './'写成这样导致改成assetsPublicPath: '/'就好了

2.prerender-spa-plugin打包出来的页面是空白的

那是因为你开启了路由的mode: 'history',这个模式需要在服务器下才能访问

而prerender-spa-plugin如果vue不开启history打包出来的都会是你

new PrerenderSPAPlugin({
  staticDir: path.join(__dirname, '../dist'),
  routes: [ '/', '/home','/brokerage'],
})

routes里面第一配置的内容,所以页面都是这个内容,所以一定要开启history模式的

而history模式必须要放在服务器里面才能跑起来的,否则是空白页

3.放在服务端的时候要放在根目录下不然也是空白的因为路由找不到

或者你可以在Router里面加上base:xxxx,来指向你对应目录又或者在每个路由的path前面加上前面的路径

如http://localhost:4388/help/index

{
path: '/help/index',
name: 'index',
component: index
},

4.子路由的静态文件路径有问题

如http://localhost:4388/help/index

里面的静态资源src="static/js/manifest.js"会变成http://localhost:4388/help/static/js/manifest.js

所以我们的assetsPublicPath: './'写成assetsPublicPath: '/'根据根目录来才不会找不到文件

5.局限

(1)没法使用动态路由

必须为要渲染的每个类别添加单独的路线,例如/catalog/:id这个ID一定要写死的

(2)商品等动态信息是动态获取的没法seo(对于门户网址致命)

(3)页面刷无法读取路由,需要服务器重定向到首页否则404

或者报错webpackJsonp is not defined(可能是我的配置错误导致)

网上说的在

new HtmlWebpackPlugin配置中加入

chunks: ['manifest', 'vendor', 'app']就可以其实并没有作用

比如我访问http://localhost:4388/会跳转到http://localhost:4388/home

而我访问http://localhost:4388/home则会跳转http://localhost:4388/home/也就是他会去找home目录下prerender-spa-plugin打包出来的index.html但是路由里好像没法处理这个路径所以会报错

这应该是history模式下的路由路径是假路径而prerender-spa-plugin打包后的路径是真路径导致的

但是我的尝试中没有像网友们说的那样会报404

如果把刷新后不要增加正斜杠/来实现的话是不是就可以了呢?(我的猜想是这样的并没有去继续专研了因为放弃了这个方案,服务器好像可以控制)

由于上面的第2个问题所以我们放弃了这个方案,后续的问题也没有处理了

prerender-spa-plugin预处理vue项目实践的更多相关文章

  1. Vue项目实践中的功能实现与要点

    本贴记录项目实践中,各种功能的实现与技术要点,均有待改进. 路由切换的时候,显示loading动画 目前方案是: 在每个页面都手动装载一个loading组件组件的显示依赖vuex里面的一个值 , 在r ...

  2. vue项目实践-前后端分离关于权限的思路

    前后端分离后权限的思路 最近看到许多关于权限的思路,但好像都是使用动态加载路由的方式,现在也分享下我在项目中使用的解决方案. 前后端分离关于权限的处理每个人都不一样,根据项目选择制定合适的方案就好 我 ...

  3. vue项目实践-添加axios封装api请求

    安装 axios npm install axios --save 创建实例 (utils/fetch.js) axios 默认提交格式为:application/json 可使用 qs 模块(需要安 ...

  4. vue项目实践-添加express-mockjs进行数据模拟

    mock-server 在新项目开始的时候,后端框架还没有,前端就有能够自己操作的模拟数据的服务是可以有的 express-mockjs 是楼教主结合 express+mock-lite 造的一个轮子 ...

  5. Vue + webpack 项目实践

    Vue.js 是一款极简的 mvvm 框架,如果让我用一个词来形容它,就是 “轻·巧” .如果用一句话来描述它,它能够集众多优秀逐流的前端框架之大成,但同时保持简单易用.废话不多说,来看几个例子: & ...

  6. nodejs, vue, webpack 项目实践

    vue 及 webpack,均不需要与nodejs一期使用,他们都可以单独使用到任何语言的框架中. http://jiongks.name/blog/just-vue/ https://cn.vuej ...

  7. Vue 项目骨架屏注入与实践

    作为与用户联系最为密切的前端开发者,用户体验是最值得关注的问题.关于页面loading状态的展示,主流的主要有loading图和进度条两种.除此之外,越来越多的APP采用了“骨架屏”的方式去展示未加载 ...

  8. Vue 项目架构设计与工程化实践

    来源 文中会讲述我从0~1搭建一个前后端分离的vue项目详细过程 Feature: 一套很实用的架构设计 通过 cli 工具生成新项目 通过 cli 工具初始化配置文件 编译源码与自动上传CDN Mo ...

  9. 【Vuejs】335-(超全) Vue 项目性能优化实践指南

    点击上方"前端自习课"关注,学习起来~ 前言 Vue 框架通过数据双向绑定和虚拟 DOM 技术,帮我们处理了前端开发中最脏最累的 DOM 操作部分, 我们不再需要去考虑如何操作 D ...

随机推荐

  1. docker中Ubuntu安装jdk1.8

    1.在宿主系统下载所需要的jdk版本的gz文件 https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133 ...

  2. Java多线程Callable和Future类详解

         public interface Callable<V>    返回结果并且可能抛出异常的任务.实现者定义了一个不带任何参数的叫做 call 的方法      public in ...

  3. codeforces 701D D. As Fast As Possible(数学)

    题目链接: D. As Fast As Possible time limit per test 1 second memory limit per test 256 megabytes input ...

  4. 通过kettle数据导入mysql时,空值的处理在插入mysql时,会自动转转换为null值,无法插入

    1.windows下C:\Users\用户名\.kettle目录中找到kettle.properties文件,增加KETTLE_EMPTY_STRING_DIFFERS_FROM_NULL=Y2.Li ...

  5. 004-画图神器-graphviz

    1 安装及基本使用 1) 下载安装 下载地址 可以下载安装版进行安装或者解压版直接使用 2) 添加系统path 为了能够在dos中使用命令, 需要添加环境变量 默认安装路径为 C:\Program F ...

  6. DIY一个DNS查询器:程序实现

    上一篇文章<DIY一个DNS查询器:了解DNS协议>中讲了DNS查询协议的原理和数据结构.经过两个星期的开发,完成了该查询器的编写.期间也遇到了一些问题,如: 1资源记录(Resource ...

  7. 使用Node.js实现简单的网络爬取

    由于最近要实现一个爬取H5游戏的代理服务器,隧看到这么一篇不错的文章(http://blog.miguelgrinberg.com/post/easy-web-scraping-with-nodejs ...

  8. bzoj4289

    最短路 很容易想到边和边之间连边,但是这样菊花图就完蛋了 我们想办法优化一下,能不能不要每条边都连. 考虑查分,把一个点的出边串起来,这样就行了,每条无向边拆成两条就能保证了 #include< ...

  9. Firebug的安装与使用

    第一步,点击 Firefox 浏览器上的“工具”选项,然后点击“附加软件”,在弹出的小窗口中,点击右下角的“获取扩展”选项,如图 4 所示. 图 4. 获取扩展 第二步,在点击“获取扩展”选项后,打开 ...

  10. js事件触发器fireEvent和dispatchEvent

    转自:https://www.cnblogs.com/tiger95/p/6962059.html 事件触发器就是用来触发某个元素下的某个事件,IE下fireEvent方法,高级浏览器(chrome, ...