当前位置: 首页 > news >正文

正因为我们是前端,所以代码更需要优雅

彩土氛褐1. 基础

1.1 图片加载优化

对于非文章类的大图片先进行一遍压缩,使用各种压缩网站就可以

然后对于各种图片最好都转换为为webp格式,相对于传统格式能降低大小大概四成左右

1.2 gzip压缩

gzip是针对文本类型进行压缩的,例如html、js、css、txt等格式,可以在nginx处打开

http {

gzip on;

gzip_buffers 32 4K;

gzip_comp_level 6;

gzip_types text/plain application/javascript text/css;

}

2. 首屏渲染

Vue类型的博客的内容是通过实时加载去渲染的,如果蜘蛛只获取了html而没有去加载js的话实际是没有内容的。有几种解决方案。

将vue渲染成静态文件,每次增加新文章都重新渲染一遍,然后上传到服务器上。优点是加载快,但是调整插件什么的比较麻烦。

实时判断爬虫然后进行服务器端渲染。

我这里主要讲一下服务端渲染。首先是nginx判断爬虫:

http {

...

server {

...

location ... {

if ($http_user_agent ~* "Sogou web spider|BingPreview|baidu|Baiduspider|twitterbot|facebookexternalhit|rogerbot|linkedinbot|embedly|quora link preview|showyoubot|outbrain|pinterest|slackbot|vkShare|W3C_Validator|bingbot|Sosospider|Sogou Pic Spider|Googlebot|360Spider|qihoobot|Googlebot-Mobile|Googlebot-Image|Mediapartners-Google|Adsbot-Google|Feedfetcher-Google|Yahoo! Slurp|Yahoo! Slurp China|YoudaoBot|Sogou spider|Sogou web spider|MSNBot|ia_archiver|Tomato Bot|Sogou web spider|soso|sogou|yahoo|sohu-search|yodao|robozilla|msnbot|MJ12bot|NHN|Twiceler|FeedDemon|JikeSpider|Indy Library|Alexa Toolbar|AskTbFXTV|AhrefsBot|CrawlDaddy|CoolpadWebkit|Java|Feedly|UniversalFeedParser|ApacheBench|Microsoft URL Control|Swiftbot|ZmEu|oBot|jaunty|Python-urllib|lightDeckReports Bot|YYSpider|DigExt|YisouSpider|HttpClient|MJ12bot|heritrix|EasouSpider|LinkpadBot|Googlebot|Ezooms") {

proxy_pass http://xxx.xxx.xxx.xxx:3000?url=https%3A%2F%2Fwww.xxxxxxxx.com${document_uri}$is_args$query_string;

}

}

}

}

逻辑就是通过请求的User-Agent判断是否是爬虫,如果是爬虫就调用一个端口为3000的服务将路径转发给它让它加载完返回加载后(js会渲染完成)的html。

至于这个端口为3000的服务,我是用了一个docker安装的镜像为zenato/puppeteer-renderer的容器,对外端口为3000,作用就是进行服务端渲染。

docker运行语句:

docker run -d --name puppeteer-renderer -p 3000:3000 zenato/puppeteer-renderer:latest

zenato/puppeteer-renderer的开源地址:https://github.com/zenato/puppeteer-renderer

3. 接口

后端服务其实没什么好说的,就是做缓存就好了,可以用Redis。另外一般返回格式为json,所以最好在nginx处加上json格式的gzip。

http {

...

gzip_types text/plain application/javascript text/css application/json;

}

4. Live2d的优化

对于live2d,基础的js和css的优化就不说了,顺便提一下live2d的图片因为要拼接起来,所以很大,记得也要压缩

这里主要说一下moc格式,moc这个是用来存live2d模型的,我这里会达到三百多k,非常占资源,其实moc是可以进行gzip压缩的,压缩后我这里会降低到一百多k,不到一半,moc进行gzip压缩有我这里有两种方案:

对nginx进行配置,再增加一个针对moc的gzip压缩

http {

...

gzip_types text/plain application/javascript text/css application/json text/x-moc;

}

蕾姆live2d

调整xx.model.json文件中的后缀

{

"model": "xx.moc.txt",

}

然后修改xx.moc为xx.moc.txt即可(需要确保nginx有做text/plain的gzip压缩)

5. 七牛云的优化

5.1 七牛云的图片瘦身

可以在七牛云的 对象存储 -> 空间管理 -> 你自己的空间 -> 多媒体样式 -> 新建样式 中配置。

我这里建议是打开图片瘦身+输出格式为webp。需要注意修改以后右侧可以看到示例链接,复制你图片的链接加上多出来的后缀即可访问。我这里访问后基本可以做到瘦身三四成的样子。

放一下配置截图:

image.png

5.2 七牛云的gzip压缩

截止到我写这篇文章的时候,七牛云会默认开启gzip加速的类型有:

text/plain

text/css

text/javascript

text/xml

application/x-javascript

application/json

application/xml

application/xml+rss

application/javascript

来源: https://developer.qiniu.com/fusion/1571/seven-niuyun-support-for-text-file-download-optimization

不能进行自定义,所以对于上面的live2d的moc文件最好调整为txt格式进行gzip压缩

6. 工具

我这里用了谷歌的 PageSpeed Insights 进行分析,分析还是很全的。

PageSpeed Insights: https://pagespeed.web.dev/?hl=zh_CN

放一下截图:

4790eaf60145dd91b3f147df0db582f0.png

可以点击七仔的博客测试我的博客速度

http://www.jsqmd.com/news/454174/

相关文章:

  • OpenClaw Windows安装教程:从踩坑到成功,9小时压缩至几步,助你打造私人AI管家!
  • 出身在二三线城市软件工作者的悲哀
  • 我被Claude Code失忆折磨了3天后,写了一个工具拯救自己
  • Hacker传说之不能说的秘密
  • 企业 FTP 替换该怎么做?
  • 【Java】踩坑实录:Spring Boot + Nginx 本地部署404终极排查:从80端口被占用到配置生效全流程
  • 微波驱动机器人:创新技术与未来应用
  • 2026年高性价比自动记录通话语音机器人厂商推荐 - 品牌2026
  • Entity Framework快速入门
  • WPF Multi-Touch 开发:Windows 安装多点触屏模拟器
  • Android整体印象
  • 2026厂房管道安装改造扩建公司哪家强?厂房管道安装工程专业公司推荐 - 品牌2026
  • rfid智能书柜排名 - 聚澜智能
  • 跑回归为什么平行趋势有些期自动Omit掉了
  • 如何在保障业务连续性的前提下实现 MySQL 负载的平滑平移?
  • 帝国cms部署https(ssl)后会员无法登录
  • Windows Azure Platform体验():SQL Azure
  • Java 程序员 和 .NET 程序员
  • 2026年超声波清洗机厂家深度测评:基于清洗效率与行业适配的五维对比。 - 品牌推荐
  • Windows Azure Platform体验():Windows Azure
  • 2026年 无机纤维喷涂厂家推荐排行榜:硬质/外墙/高铁机场/电梯井/地下室/车库顶板/厂房/矿物/超细无机纤维棉喷涂,专业防火隔音工程解决方案 - 品牌企业推荐师(官方)
  • C#会重蹈覆辙吗?系列之:华而不实的C#析构器
  • 2026年美国移民公司深度测评:基于法律合规与案例实效的五维对比分析 - 品牌推荐
  • 综述:编程语言的发展趋势及未来方向
  • 2026无纸化会议室会议系统优质品牌推荐榜 - 优质品牌商家
  • Windows上安装Go并配置环境变量(图文步骤)
  • 开发者必备:【Java】 设计模式从入门到精通
  • 2026 年贵州省变频器厂家优质推荐 本土实力企业甄选指南 - 深度智识库
  • 2026年高端智能语音机器人厂商盘点及智能语音应答机器人实力对比 - 品牌2026
  • 基于HFSS的宽带圆极化天线设计