如何为Docusaurus站点接入AdSense广告SDK

Docusaurus是一个基于React的快速建站工具,与基于Vue的快速建站工具VuePress有很多相似之处。该项目由Facebook团队开发,并开源。

与VuePress一样,Docusaurus支持通过Markdown格式编写网页,并可以基于文件系统的目录结构生产对应的路由,而且也支持通过插件的方式来扩展功能。

问题背景

Docusaurus官方提供了一些常见的插件,包括谷歌统计ga4,或者google tag manager,但是却没有提供AdSense变现SDK的插件。

网站建设好后,想要通过AdSense进行变现,该如何添加呢?

如果不想花大力气去修改主题,最便捷的方法莫过于自己编写一个简单的AdSense插件plugin了。

解决方法

第一步,编写My AdSense Plugin

官方文档

https://docusaurus.io/docs/advanced/plugins

Docusaurus支持多种创建插件的方法:

  • 直接使用匿名函数
  • 使用独立模块

为了方便维护,本例使用第二种。

  • 首先,在项目的根目录下创建插件目录,并添加插件的入口文件index.js:my-plugin/index.js

  • 编写plugin对应的生命周期接口方法
    plugin支持的接口,参考文档:

https://docusaurus.io/docs/api/plugin-methods/lifecycle-apis

为了引入AdSense SDK需要使用injectHtmlTags
示例代码:

module.exports = async function myAdSensePlugin(context, options) {
  // ...
  return {
    name: 'adsense-plugin', // 插件的名称
    injectHtmlTags({content}) {
      // console.info("===> adsesne-plugin injectHtmlTags")
      clientID = options.clientID; // 读取配置的AdSense id
      return {
        headTags: [  // 插入到header部分的代码
          {
            tagName: 'script',
            attributes: {
              async: true,
              crossorigin: 'anonymous',
              src: `https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=${clientID}`,
            },
          },
        ],
      };
    },    
  };
};

第二步,引入插件并设置AdSense变现账号

为了灵活使用,一般把可变参数作为插件的配置项。上边的代码中,我们用clientID作为AdSense的id,并在代码中引入。

插件代码编写好后,需要在docuraurus.config.js中的plugins项中引入插件:

  plugins: [
    ['./adsense-plugin', // 要引入的插件的目录
    { 
      clientID: '<这里填AdSense id>', // 设置参数
    }],
  ],

如何引入和配置插件,参考文档:

第三步,重新编译并发布站点

一切就绪,重新编译并发布,在网络请求中就可以看到对应的请求了。