给大家推荐一个vue 单页面搜索引擎无法SEO的解决办法


这两天用Vue3做了一个免费下载书籍的小网站,https://book.usejs.cn;大家可以先看下效果
前端项目做完、部署了之后想让搜索引擎能够收录一下我的这个网站,可是众所周知的是,vue做的网页都是单页面程序,搜索引擎SEO的时候对这个的支持极不友好,特别是某度,听说谷歌、必应已经开始支持单页面网页了,yes!
说回对SEO的支持;接下来我就开始在网上找相关的解决办法。网上的文章大都是说用nuxt服务端渲染的方法,但由于我之前做过一个nuxt的玩具项目,因为服务器性能原因最后放弃了。而且vue项目转nuxt有点麻烦,这个方法我就不考虑了;
然后我又在网上继续找,最后发现一篇文章说的一个方法很精妙,当普通用户正常的时候服务器返回单页面程序,检测到爬虫的时候就用puppeteer这个库返回已经加载好了的html;我一看这个方法可行性很高,因为前段时间玩了很久的puppeteer,不用担心不会用;
方法找到了接下来开始干活了;当我准备自己写代码的时候,发现已经有了一个rendertron库,给大家说戏使用方法

rendertron使用方法

首先全局安装rendertron

npm i rendertron -g
// 然后直接在命令行里面执行rendertron就可以了

默认端口3000在浏览器里面输入

   http://127.0.0.1:3000/render/https://book.usejs.cn

就能渲染爬取后的页面html页面了,render后面接的需要渲染的单页面网址;
准备好了之后就是创建一个服务作为中介,遇到爬虫的时候就返回rendertron渲染后html代码了;
官方的推荐是使用express代码如下

// server/index.js
const express = require('express');
// rendertron express 官方中间件
const rendertron = require('rendertron-middleware');
const app = express();// history 路由兼容中间件
const history = require('connect-history-api-fallback'); // 这个插件很有用
let port = process.env.PORT || 8080;// 注册中间件  默认是 /index.html
app.use(history());app.use(rendertron.makeMiddleware({proxyUrl: 'http://127.0.0.1:3000/render', // 默认rendertron是3000端口
}));// spa项目打包完成的目录
app.use(express.static('dist')); //  静态目录设置一定要在makeMiddleware 中间使用的后面
app.listen(port, function () {console.log('http://127.0.0.1:' + port);console.log('listening to ' + port);
});

完活
react应该也能使用

下一期给你们说在linux上服务器部署代码,遇到的各种各样的坑;如puppeteer安装、运行,没有字体等;
最后这个网大家可以看一下rendertron效果
免费下载书籍的小网站,https://book.usejs.cn;
这是最后完成的网站,大家可以访问看下效果,普通访问返回的都是vue单页面内容,当请求头是爬虫的时候返回的就是加载完成的html,使用apipost可以看到效果

给大家推荐一个Vue 单页面程序无法SEO的解决办法相关推荐

  1. puppeteer-不需重构,无痛加强vue单页面应用的SEO,提升百度收录排名

    背景 最近产品觉得我们网站在百度收录上排名太靠后了,又不肯花钱,就让我们想办法提升网站的SEO.由于项目是用vue3写的,并且已经迭代多个版本了,用nuxt实在不适宜,当然俺的开发水平也不够,周期也会 ...

  2. vue单页面程序对谷歌GA事件的应用

    公司运营最近在对网页做用户转化率调查这块,找到了谷歌GA事件.按照之前GA官网给出的文档,把代码加入到了index.html里面,一周后发现统计出来的数据跟后台数据库对比对不上. 经过一番研究后,发现 ...

  3. 404 单页应用 报错 路由_通过 Laravel 创建一个 Vue 单页面应用(五)

    文章转发自专业的Laravel开发者社区,原始链接:https://learnku.com/laravel/t/34858 我们在第4部分完成了编辑用户的功能,并且学习了如何使用 v-model 来监 ...

  4. 在不使用ssr的情况下解决Vue单页面SEO问题

    遇到的问题: 近来在写个人博客的时候遇到了大家可能都会遇到的问题 Vue单页面在SEO时显得很无力,尤其是百度不会抓取动态脚本 Vue-Router配合前后端分离无法让meta标签在蜘蛛抓取时动态填充 ...

  5. SPA优缺点、解决单页面应用的SEO困难问题以及三种网页渲染方式

    SPA特点优点缺点总结 1. 单页Web应用(SPA - Single Page web Application) 也就是说只有一个HTML文件的Web应用, 我们就称之为单页Web应用, 就称之为S ...

  6. php vue seo,处理 Vue 单页面 SEO 的另一种思路

    (设置vue 单页面meta info信息,如果需要单页面SEO,可以和 prerender-spa-plugin形成更优的配合) 单页面应用在前端正大放光彩.三大框架 Angular.Vue.Rea ...

  7. 基于angularjs的单页面实例_基于AngularJs的单页面程序

    基于AngularJs的单页面程序 在Abpzero的后台管理系统是一个AngularJs的单页面程序.当你登陆后,系统会跳转到"ApplicationController",然后 ...

  8. seo需要处理页面html,详解处理Vue单页面应用SEO的另一种思路

    (设置vue 单页面meta info信息,如果需要单页面SEO,可以和 prerender-spa-plugin形成更优的配合) 单页面应用在前端正大放光彩.三大框架 Angular.Vue.Rea ...

  9. 前端复盘: knockout + require + director 构建单页面程序

    关注并将「趣谈前端」设为星标 每早08:30按时推送技术干货/优秀开源/技术思维 目前react,vue,angular等框架都支持单页面程序,最近在回顾一些知识,想起刚毕业的时候接触到knockou ...

最新文章

  1. Nginx(一)------简介与安装
  2. PostgreSQL — 外键关联操作
  3. 设计模式——代理模式
  4. Python:Selenium 1:浏览器驱动
  5. 来自Riot 的一份游戏美术教程(一):核心原则
  6. 中文字体练习好看的手写字
  7. 360 自动打开word_Word文档高手的组合键用法,你知道几个?
  8. N85通过wifi共享笔记本电脑网络的方法
  9. [Java基础]复制文件的异常处理try...catch...finally的做法
  10. 计算机专业学生求职信500字,计算机专业求职信500字范文
  11. netfilter与用户空间通信
  12. 自底向上带你逆向解析hibernate联合主键
  13. iOS弹幕库OCBarrage-如何hold住每秒5000条巨量弹幕
  14. Webmax 2.0开启无限量下载
  15. jqGrid实现冻结行和冻结列
  16. css中flex设置为1是什么意思
  17. iTunes 12恢复.ipsw固件
  18. python flask 读取地址栏参数
  19. Oculus客户端在Win10上面无法安装或者登陆的解决方法
  20. GPON Type B保护

热门文章

  1. 一文掌握常用的机器学习模型
  2. 三级pc技术_三级推广分销佣金模式解读
  3. 【Unity3DRPG入门学习笔记第二卷】Build Level 熟悉基本工具
  4. 转载:非常实用的15款开源PHP类库
  5. 关于微信公众号搭建H5网页时 网页授权域名配置问题
  6. 网络保护第一层: 防火墙介绍
  7. 优化数据中心机架和设备的 5 个理由
  8. 分页插件 limit使用失败
  9. 亚马逊究竟适不适合季节性商品?选品思路
  10. 2022-2027年中国团膳行业市场全景评估及发展战略规划报告