成分标注

B站评论区成分标注,依据是动态里是否有相关内容(基于三相指示器修改)

目前为 2022-09-13 提交的版本。查看 最新版本

// ==UserScript==
// @name         成分标注
// @namespace    Cloudwish
// @version      0.11
// @description  B站评论区成分标注,依据是动态里是否有相关内容(基于三相指示器修改)
// @author       cloudwish
// @match        https://www.bilibili.com/video/*
// @match        https://t.bilibili.com/*
// @match        https://space.bilibili.com/*
// @match        https://space.bilibili.com/*
// @match        https://www.bilibili.com/read/*
// @icon         https://static.hdslb.com/images/favicon.ico
// @connect      bilibili.com
// @grant        GM_xmlhttpRequest
// @license MIT
// @run-at document-end
// ==/UserScript==
 
 
(function () {
    'use strict';
 
    //成分,可自定义
    var tag_data = {
        "抽奖": {
            "html": "<b style='color: #6495ED'>【抽奖】</b>",
            "keyword": ["抽奖"]
        },
        "原批": {
            "html": "<b style='color: #6495ED'>【原批】</b>",
            "keyword": ["原神"]
        },
        "舟批": {
            "html": "<b style='color: #6495ED'>【舟批】</b>",
            "keyword": ["明日方舟"]
        },
        "维阿信": {
            "html": "<b style='color: #6495ED'>【维阿信】</b>",
            "keyword": ["VirtuaReal"]
        },
        "脆鲨": {
            "html": "<b style='color: #6495ED'>【脆鲨】</b>",
            "keyword": ["七海Nana7mi"]
        },
        "棺材铺": {
            "html": "<b style='color: #6495ED'>【棺材铺】</b>",
            "keyword": ["东雪莲", "東雪蓮"]
        },
    }
    // 合并规则,合并时每个tag只会计算一次,优先级从上到下
    var tag_merge_rule_list = [
        {
            "html": "<b style='color: #6495ED'>【原舟双批】</b>",
            "tag": ["原批", "舟批"]
        },
    ]
 
    const blog = 'https://api.bilibili.com/x/polymer/web-dynamic/v1/feed/space?&host_mid='
    const is_new = document.getElementsByClassName('item goback').length != 0 // 检测是不是新
 
    const get_uid = (user) => {
        if (is_new) {
            return user.dataset['userId']
        } else {
            return user.children[0]['href'].replace(/[^\d]/g, "")
        }
    }
 
    const get_comment_user_list = () => {
        if (is_new) {
            let lst = new Set()
            for (let user of document.getElementsByClassName('user-name')) {
                lst.add(user)
            }
            for (let user of document.getElementsByClassName('sub-user-name')) {
                lst.add(user)
            }
            return lst
        } else {
            return document.getElementsByClassName('user')
        }
    }
 
    console.log(is_new)
    console.log("正常加载")

    for(const tag in tag_data) {
        tag_data[tag]["html"] = tag_data[tag]["html"].replaceAll("'", '"')
    }

    for(var rule of tag_merge_rule_list) {
        rule["html"] = rule["html"].replaceAll("'", '"')
    }

    var user_html = {}
 
    let jiance = setInterval(() => {
        let user_list = get_comment_user_list()
        if (user_list.length != 0) {
            // clearInterval(jiance)
            user_list.forEach(user => {
                let uid = String(get_uid(user))
                if(!(Object.keys(user_html).includes(uid))) {
                    user_html[uid] = ""
                    let blogurl = blog + uid
                    // let xhr = new XMLHttpRequest()
                    GM_xmlhttpRequest({
                        method: "get",
                        url: blogurl,
                        data: '',
                        headers: {
                            'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.0.0 Safari/537.36'
                        },
                        onload: function (res) {
                            if (res.status === 200) {
                                let str = JSON.stringify(JSON.parse(res.response).data)
                                let tag_set = new Set()
                                for(const tag in tag_data) {
                                    for(const keyword of tag_data[tag]["keyword"]) {
                                        if(str.includes(keyword)) {
                                            tag_set.add(tag)
                                            break
                                        }
                                    }
                                }
                                for(const merge_rule of tag_merge_rule_list) {
                                    let is_merge = true
                                    for(const tag of merge_rule["tag"]) {
                                        if(!tag_set.has(tag)) {
                                            is_merge = false
                                            break
                                        }
                                        if(is_merge) {
                                            for(const tag of merge_rule["tag"]) {
                                                tag_set.delete(tag)
                                            }
                                            user_html[uid] += merge_rule["html"]
                                        }
                                    }
                                }
                                for(const tag of tag_set) {
                                    user_html[uid] += tag_data[tag]["html"]
                                }
                                user.innerHTML += user_html[uid]
                            } else {
                                console.log('获取UID'+uid+'用户的动态失败')
                                console.log(res)
                            }
                        },
                    });
                }
                else if(!user.innerHTML.replaceAll("'", '"').includes(user_html[uid])){
                    user.innerHTML += user_html[uid]
                }
            });
        }
    }, 5000)
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址