前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于这几日对博客做的一些优化·贰

关于这几日对博客做的一些优化·贰

作者头像
Cesirdy
发布2023-05-29 14:08:14
1970
发布2023-05-29 14:08:14
举报
  1. 又对博客优化了一波。

CDN

都上备案了,不能白跑一趟,火速上了又拍云的 CDN 加速,说实话我对 CDN 这方面完全不懂,只能随便设置两下,但是提升还是很大的。

一些设置

全局缓存一天(源站资源迁移的生效条件是缓存过期时间必须大于 24 小时) 分段缓存 智能压缩均拉到3级 页面压缩打开 证书使用了腾讯云免费发的,直接上传就能用了。 TLS 1.3 开启,最低 TLS 1.0 开启 HTTP/2 + Server Push (自动推送 css 和 js ) 想少挨点打,还是开了 IP 限制:一分钟内超过50个请求就屏蔽10分钟 CC 防护打开 WAF 保护打开 WebP 自适应打开

DNS

境外访问解析到 Vercel,国内则解析到又拍云。

一波操作后,直接就是绿油油一片o( ̄▽ ̄)ブ

好快的斯比的
好快的斯比的

好快的斯比的

JS 优化

加入了懒加载、谷歌统计和 Service Worker。然后把 InstantClick 去掉了。

懒加载

使用了 lazysizes。 使用及其方便,只需引入一行 <script> 即可:

<script src="lazysizes.min.js" async></script>

然后我们需要给 <img> 设置 class="lazyload" data-src="..." Hexo 可以在主题中加入 helper 来影响生成的文件,直接将helper放入主题目录的 scripts 文件夹里就会自动启用了。这里直接从 Butterfly 主题抄了份:

/**
 * Butterfly
 * lazyload
 * replace src to data-lazy-src
 */

'use strict'

const urlFor = require('hexo-util').url_for.bind(hexo)

function lazyload (htmlContent) {
  const bg = hexo.theme.config.lazyload.placeholder ? urlFor(hexo.theme.config.lazyload.placeholder) : ''
  return htmlContent.replace(/(<img.*? src=)/ig, `$1 "${bg}" data-lazy-src=`)
}

hexo.extend.filter.register('after_render:html', function (data) {
  const config = hexo.theme.config.lazyload
  if (!config.enable) return
  if (config.field !== 'site') return
  return lazyload.call(this, data)
})

hexo.extend.filter.register('after_post_render', data => {
  const config = hexo.theme.config.lazyload
  if (!config.enable) return
  if (config.field !== 'post') return
  data.content = lazyload.call(this, data.content)
  return data
})

按照自己需求改动即可。

谷歌统计

不知道是什么时候谷歌统计已经升级成了 gTag.js,总之要兼容 InstantClick 我是不知道怎么弄,总是重复发生请求,一次访问会统计两次。 既然解决不了问题,那就解决掉提出问题的人,直接对 InstantClick进行一个 Delete。

Service Worker

老东西了,貌似现在还有升级版,不过我这个主题最初编写的时候就有加入 sw.js,后来因为和 InstantClick 冲突就注释掉了。这下又能开起来了。

"serviceWorker"in navigator&&navigator.serviceWorker.register("/sw.js")

Instant.Page

删除 InstantClick 主要是发现了作者的另一个项目 Instant.Page,使用起来更方便一些,效果也相差无几。

<script src="instantpage-5.1.0.js" type="module" defer></script>

原理主要是利用 <link rel="prefetch" href="url"> 来预加载页面之后缓存起来,在点开链接的时候就可以直接使用缓存的内容。 默认是在鼠标悬停链接上65ms后开始预加载,但是这样有可能造成浪费,可以在 <body> 加入 data-instant-intensity="mousedown" 更改为鼠标按下时开始预加载。 也有像 data-instant-intensity="viewport-all" 全屏预加载这种丧心病狂的设置。之后或许会单独出一篇文章介绍 Instant.Page。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • CDN
    • 一些设置
      • DNS
      • JS 优化
        • 懒加载
          • 谷歌统计
            • Service Worker
              • Instant.Page
              相关产品与服务
              内容分发网络 CDN
              内容分发网络(Content Delivery Network,CDN)通过将站点内容发布至遍布全球的海量加速节点,使其用户可就近获取所需内容,避免因网络拥堵、跨运营商、跨地域、跨境等因素带来的网络不稳定、访问延迟高等问题,有效提升下载速度、降低响应时间,提供流畅的用户体验。
              领券
              问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档