gitee pages 自动更新新思路

使用 puppeteer 实现 gitee pages 自动更新

gitee pages 博客痛点是即使发布了最新的代码,依旧无法像 github 博客一样自动更新站点。除了大佬通过 git Actions 可以完成自动更新,就是手动点击 ,我介个 就是把手动点击界面的操作脚本话,在自己的博客项目 package.json 中配置一个命令映射到执行脚本即可。
puppeteer 官方文档

开始

初始化项目

bash 复制代码
yarn add puppeteer -D

新建文件

index.js

js 复制代码
const path = require("path");

const puppeteer = require("puppeteer");

const browser = async () => {
  const browser = await puppeteer.launch({ headless: false });

  // 创建一个新界面
  const page = await browser.newPage();

  // 前往登录页
  await page.goto("https://gitee.com/login");

  // 用户名组件
  const userNameHandle = await page.evaluate(() => {
    const userNameHandle = document.querySelector("#user_login");
    userNameHandle.value = "Gitee 名称";
  });

  // 密码操作
  const passworldHandle = await page.evaluate(() => {
    const pwdElements = document.querySelector("#user_password");
    pwdElements.value = "Gitee 密码";
  });

  const loginBtnHandle = await page.evaluate(() => {
    const btnElements = document.querySelector(".submit");
    btnElements.click();
  });

  // 等待登录成功
  await page.waitForResponse("https://gitee.com/login");

  // 按钮更新界面
  await page.goto("https://gitee.com/Gitee 页面名称/pages");

  // 监听 弹窗事件
  await page.on("dialog", async (dialog) => {
    dialog.accept();

    await page.waitForTimeout(1000);

    await page.evaluate(() => {
      // 定时器判断是否还在定时状态
      const timer = setInterval(async () => {
        const updateLoadingElement = document.querySelector("#pages_deploying");

        // 元素不存在即更新完成
        if (!updateLoadingElement) {
          timer.clearInterval();

          await page.waitForTimeout(1000);

          // 更新完毕
          page.close();

          throw "更新完毕";
        }
      }, 1000);
    });
  });

  const updateHandle = await page.evaluate(() => {
    const updateElements = document.querySelector(".update_deploy");
    updateElements.click();
  });
};

browser();

缺点

如果 dom 结构发生改变脚本要重写。

PS

  • 后续会持续更新相关内容以及其他内容
  • 觉得文章不错的话,记得 👍 🌟 嘻嘻
  • 如有不足欢迎指正
相关推荐
-To be number.wan2 小时前
C++ 赋值运算符重载:深拷贝 vs 浅拷贝的生死线!
前端·c++
噢,我明白了3 小时前
JavaScript 中处理时间格式的核心方式
前端·javascript
纸上的彩虹4 小时前
半年一百个页面,重构系统也重构了我对前端工作的理解
前端·程序员·架构
be or not to be4 小时前
深入理解 CSS 浮动布局(float)
前端·css
LYFlied4 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞5 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小徐_23335 小时前
2025 前端开源三年,npm 发包卡我半天
前端·npm·github
GIS之路5 小时前
GIS 数据转换:使用 GDAL 将 Shp 转换为 GeoJSON 数据
前端
JIngJaneIL6 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
天天扭码6 小时前
以浏览器多进程的角度解构页面渲染的整个流程
前端·面试·浏览器