Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

为 Hugo 添加 Pagefind 搜索

Posted on 2025-02-04

opengraph2.jpg

Pagefind让我很高兴。它是一个静态搜索库,配置和使用起来非常简单,我简直不敢相信。以下是我如何在 Anubis2 Hugo 主题1中实现 Pagefind 搜索的快速总结。

我首先创建 content/search.md 作为搜索页面的内容。在该文档中,我粘贴了Pagefind 入门文档中的默认代码…

 < link href = "/pagefind/pagefind-ui.css" rel = "stylesheet" > < script src = "/pagefind/pagefind-ui.js" ></ script > < div id = "search" ></ div > < script > window .addEventListener( 'DOMContentLoaded' , (event) => { new PagefindUI({ element : "#search" , showSubResults : true }); }); </ script >

为了构建搜索索引,我通过 NodeJS 运行它,如下所示:

 npx -y pagefind --site public

就是这样!这就是技术上所需要的全部。运行索引器会创建索引并将必要的支持(css/js)文件放入 public/pagefind/ 中。只需部署站点2并访问 /search。

默认情况下,Pagefind 索引<body>元素中的所有内容。这太多了,所以我将data-pagefind-body添加到“single.html”模板中仅包含帖子内容的元素中。

 < div data-pagefind-body class = "content e-content" >  </ div >

对于标题,我需要<H1>元素中的data-pagefind-meta="title" :

 < h1 data-pagefind-meta = "title" class = "p-name post-title favorite draft" ></ h1 >

我在导航中放了一个小搜索图标。这一切花了我不到 30 分钟的时间。太疯狂了。

我确信我会进一步调整,但开箱即用的体验非常棒。

自己尝试一下。


  1. Pagefind 适用于任何静态网站。我在这里使用雨果。 ↩︎

  2. 我还将索引步骤添加到我的部署脚本中,以便索引始终是最新的。 ↩︎

通过电子邮件回复此帖子

原文: https://baty.net/posts/2025/01/adding-pagefind-search-to-hugo/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme