雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

简单的tampermonkey插件开发实例

2024-04-15 分类:前端之旅 阅读(461) 评论(0)

今天在看抖音开放平台的数据的时候, 看到那个用户挂载列表里, 不显示挂载者的抖音号, 只显示头像昵称,找人特别不方便;

iShot_0006-04-15_10.35.51如图, 我跟根据昵称去找人, 搜到一堆人,根本找不见~~~

翻了一下 api, 看他接口有返回, 只是没有显示出来

于是想到开发个tampermonkey 插件来解决 !

插件流程也很简单, 我监听他这个列表数据接口, 接口数据返回, 我就拦截并且把抖音号插入到列表里!

简简单单写几行代码!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
// ==UserScript==
// @name         监听接口数据示例
// @namespace    https://developer.open-douyin.com/
// @version      0.1
// @description  监听指定接口返回数据并备份数据在变量里
// @match        https://developer.open-douyin.com/bff_api_v2/app/data/dataService/getShortOrLiveDataWithId\
// @match        *.open-douyin.com/*
// @grant        GM_xmlhttpRequest
// ==/UserScript==
 
(function() {
 
    const findClass = (txt, append = '')=> {
        const searchChar = txt;
        // 获取页面上所有的 div 元素
        const divs = document.querySelectorAll('span');
        // 遍历每个 div 元素
        divs.forEach(div => {
            // 检查 div 的文本内容是否包含搜索的汉字
            if (div.innerText.includes(searchChar)) {
                // 如果包含,则执行相应的操作
                console.log("找到包含汉字 '汉' 的 div:", div);
                // 例如,你可以修改其背景色
                div.style.backgroundColor = "yellow";
                div.innerText = `昵称:` + searchChar + `, 抖音号:` + append;
            }
        });
    }
    var open = XMLHttpRequest.prototype.open;
    XMLHttpRequest.prototype.open = function(method, url, async, user, pass) {
        this.addEventListener('readystatechange', function() {
            if (this.readyState == 4 && this.status == 200) {
                var oldResponse = this.responseText;
                // 修改响应数据
                if(url === `/bff_api_v2/app/data/dataService/getShortOrLiveDataWithId`){
                    const list = JSON.parse(oldResponse);
                    console.log('原始响应:', list);
                    console.log(`url`, url);
                    const useList = list?.data?.DataList ?? [];
                    setTimeout(_=> {
                        useList.map(val=> {
                            findClass(val.item_aweme_name, val.item_aweme_shortid)
                        })
                    }, 1000)
                }
 
            }
        }, false);
        open.apply(this, arguments);
    };
})();

 

最后把昵称标记为黄色, 并且把抖音号追加显示出来~

iShot_0006-04-15_10.39.23

分享到:更多 ()

相关推荐

  • AI 编辑器 cursor 如何禁止自动更新
  • AI 编辑器 cursor 工具栏改成和 vscode 一样的左侧 竖向展示
  • nodejs 脚本打包为可执行文件
  • 初学 python 笔记
  • nodejs 同时运行多个脚本
  • 让你的照片动起来
  • vue工程项目动态加载umd.js实践
  • 使用 shell 检测目标服务器是否异常
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • 百度你个大毒瘤 - 吐糟博客这几天打不开事情-雅荷心语博客百度你个大毒瘤 – 吐糟博客这几天打不开事情2015-12-28评论(2)
  • PHP 非对称加密 openssl 加密及解密方法-雅荷心语博客PHP 非对称加密 openssl 加密及解密方法2016-05-17评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
2025年7月
一 二 三 四 五 六 日
« 六    
 123456
78910111213
14151617181920
21222324252627
28293031  

最新评论

  • 前端小武 8年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 8年前 (2017-03-03)说:
  • Dawn 9年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 9年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 9年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

其他类型

  • 芊云全景
  • 配音兔AI配音神器

博客类型

  • 芊云全景
  • 配音兔AI配音神器

左邻右舍

  • 易水寒
  • 楼教主
  • 芊云全景
  • 贤心
  • 配音兔AI配音神器

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2025 雅荷心语博客   网站地图