
优化网站在 Google 的搜索结果
为网站增加 Google 搜索,让 Google 快速收录你的网站并优化搜索结果。
为自己的站点添加搜索功能,我们可能会考虑 Algolia 或者 pagefind 这样的搜索服务。他们都需要一定的开发成本,而且可能需要付费。
如果你的站点是一个静态站点,可以考虑使用 Google 搜索。Google 搜索不需要付费,只需要在站点中添加一个搜索框,然后将搜索结果展示在 Google 的搜索结果中。
为网站增加 Google 搜索
- 在站点中添加搜索框
- 点击搜索跳转到 Google 的搜索结果页面
tsx
1// 将 site 改为你的站点名 2export const navigateToGoogleSearch = (text: string) => { 3 const encodedText = encodeURIComponent(`site:haydenhayden.com ${text}`) 4 window.open(`https://www.google.com/search?q=${encodedText}`, '_blank') 5}

我们可以监听 input 的 keydown 事件,当按下回车键时,触发回调函数。
但是中文输入法回车可能误触发搜索,我们可以通过 isComposing 属性来判断是否需要触发搜索。
tsx
1<Input 2 onKeyDown={(e) => { 3 if (e.key === 'Enter' && !e.nativeEvent.isComposing) { 4 onClickSearch() 5 } 6 }} 7/>
让 Google 收录你的网站
可以在 Google 搜索 site:your-site.com 查看你的站点是否被 Google 收录。如果搜索结果为空,就说明你的站点还没有被 Google 收录。
可以通过 Google Search Console 来提交你的站点,让 Google 收录你的站点。

我这里采用的认证方式是添加 TXT 记录到域名的 DNS 中。你也可以选择其他的认证方式。
认证完成后,我们的网站只是被收录了,但是我们还需要让网站的页面被索引。只有被索引,才代表这个页面的内容被爬虫收录到了 Google 的数据库中。
为了让爬虫更快地爬取页面,我们需要一个文件来告诉爬虫哪些页面需要被爬取。
添加 sitemap
sitemap 是一个 XML 文件,用来告诉搜索引擎哪些页面需要被爬取。如果你的页面是静态的,可以使用 XML-Sitemaps.com 之类的生成工具来生成 sitemap 文件。
我的站点是使用 Next.js 构建的,所以我需要一个动态的 sitemap 文件。
- 在 public中添加robots.txt文件
txt
1Sitemap: https://haydenhayden.com/sitemap.xml
告诉搜索引擎 sitemap 文件的地址。
- 添加 sitemap.xml文件
新建文件,路径为 src/app/sitemap.xml/route.ts。
获取所有文章,生成 sitemap 内容
ts
1const blogs = await getBlogs() 2const sitemap = `<?xml version="1.0" encoding="UTF-8"?> 3 <urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"> 4 <url><loc>https://haydenhayden.com</loc></url> 5 ${blogs 6 .map(({ date, slug, type, sitemapPriority }) => { 7 const url = getUrl(`/${type}/${slug}`).href 8 return getXml({ date: updatedDate ?? date, url, priority: sitemapPriority }) 9 }) 10 .join('\n')} 11 </urlset>` 12 13function getUrl(path = '') { 14 return new URL(path, 'https://haydenhayden.com') 15} 16function getXml({ 17 date, 18 url, 19 changefreq = 'monthly', 20 priority = 0.5, 21}: { 22 date: Date 23 url: string 24 changefreq?: 'always' | 'hourly' | 'daily' | 'weekly' | 'monthly' | 'yearly' | 'never' 25 /** 0.0 ~ 1.0 */ 26 priority?: number 27}) { 28 return `<url> 29 <loc>${url}</loc> 30 <lastmod>${date.toISOString()}</lastmod> 31 <priority>${priority}</priority> 32 <changefreq>${changefreq}</changefreq> 33</url>` 34}
详细的 xml 格式可以参考 Sitemap Protocol Format。
| 属性 | 描述 | 
|---|---|
| loc | 页面的 URL | 
| lastmod | 页面最后修改时间 | 
| priority | 页面的优先级,0.0 ~ 1.0,1.0 为最高优先级 | 
| changefreq | 页面内容的更新频率,always, hourly, daily, weekly, monthly, yearly, never | 
一个简单的 sitemap 文件示例:
xml
1<?xml version="1.0" encoding="UTF-8"?> 2<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9"> 3 <url> 4 <loc>https://haydenhayden.com/blog/google-search</loc> 5 <lastmod>2024-04-28T00:00:00.000Z</lastmod> 6 <priority>0.5</priority> 7 <changefreq>weekly</changefreq> 8 </url> 9</urlset>
- 返回 sitemap 文件
ts
1export async function GET() { 2 // 获取 sitemap 3 return new Response(sitemap, { 4 headers: { 5 'content-type': 'text/xml', 6 }, 7 }) 8}
完整代码参考 haydenhayden.com sitemap.xml
- 提交 sitemap 到 Google Search Console

请求索引指定页面
当我们的站点有新的页面发布时,Google 往往需要一周到一个月的时间才能爬取到新的页面。如果我们希望 Google 尽快爬取新的页面,可以通过 Google Search Console 请求索引指定页面。
比如我这里的一篇周刊 https://www.haydenhayden.com/weekly/weekly-110 发布于 24 天前,但是 Google 还没有爬取到这个页面。

我们搜索关键词 贴纸,结果为空。

点击页面中的 请求索引,Google 会将爬取这个页面的任务放到优先队列里。

等待一段时间 (可能几个小时也可能一天),出现如下提示,说明 Google 已经爬取到这个页面。再次搜索关键词 贴纸,就可以看到这个页面的搜索结果了。

