// ==UserScript== // @name WarframeMarketTranslation // @version 0.31 // @description WarframeMarket Translation ,翻译 WarframeMarket 的商品对照中英文,英文游戏购买可以直接快速看见商品名,不需要开两个网页对照了 // @author Boomer // @match https://warframe.market/zh-hans/profile/* // @icon https://warframe.market/favicon.ico // @grant none // @license MIT // @namespace https://greasyfork.org/users/1327824 // @downloadURL none // ==/UserScript== // 定义一个空数组来记录值,记录该商品的行是否被生成过出售语句中 const recordedValues = ["想要卖"]; // 创建一个标志来跟踪是否已经插入 let isInserted = false; // 创建允许快速复制的快速出售裂罅武器文本框 function createPurpleCardSellsStatementTextBox() { // 如果已经插入过,则不再执行 if (isInserted) { return; } // 查找目标元素位置 var targetElement = document.querySelector('#panel > section.flex--root.ad__line--je1R0 > div.container'); // 创建一个新的 div 元素 var purpleCardSellsStatementTextBox = document.createElement('div'); // 使用正确的方法设置类名 purpleCardSellsStatementTextBox.classList.add('row', 'auction-entry__body', 'no-gutters'); // 组装武器名称 const outputString = recordedValues.join(" "); // purpleCardSellsStatementTextBox.textContent = outputString; // 创建一个 span 元素 var purpleCardSellsStatementSpan = document.createElement('span'); purpleCardSellsStatementSpan.textContent = outputString; // 将 span 元素添加到 div 中 purpleCardSellsStatementTextBox.appendChild(purpleCardSellsStatementSpan); // 将新的 div 元素插入到目标元素中 targetElement.appendChild(purpleCardSellsStatementTextBox); // 设置标志为 true,表示已经插入过 isInserted = true; } window.addEventListener("wheel", function () { (function () { "use strict"; // todo: 方法二 // 监听滚轮事件 window.addEventListener("wheel", function () { var commonProductPath = document.querySelector("#panel > section.user__profile.content--UwhYJ.grow--Q24fj > div.content__header--mFlr5.flex-root > div.container > div > ul > li:nth-child(1) > a"); var crackTheCommodityPath = document.querySelector("#panel > section.user__profile.content--UwhYJ.grow--Q24fj > div.content__header--mFlr5.flex-root > div.container > div > ul > li:nth-child(2) > a"); // 判断当前是否在普通 "订单" 页面 if (commonProductPath.className == "link smartLink--bBcyL active") { // 商品内容 let ProductContents = document.getElementsByClassName("infinite-translate"); let WarframeMarketWantToSell = ProductContents[0]; let WarframeMarketWantToSellNode = Array.from(WarframeMarketWantToSell.childNodes); // 测试使用 // console.log("WarframeMarketWantToSellNode 长度为 :" + WarframeMarketWantToSellNode.length); // 使用 for 循环遍历WarframeMarketWantToSellNode并修改匹配的元素 for (let i = 0; i < WarframeMarketWantToSellNode.length; i++) { // 选择 商品的超链接 从中截取英文名称 let selector = `#panel > section.user__profile.content--UwhYJ.grow--Q24fj > div.content__body--qkyqR.flex--root > div.container > div.order__content--ORU7n > div.sellOrders--nsRSO.listingSell > div.infinite-scroll > div > div:nth-child(${i + 1}) > div.order-own__item-name--K7IDS > a`; let selectorElement = document.querySelector(selector); // 给超链接标签添加些缩进,方便更好的复制 // 处理 英文名称 let SelectorTheEnglishNameOfTheProduct = selectorElement.getAttribute("href").replace("/zh-hans/items/", ""); // 选择 商品名称 let elementToModify = selector + ` > span`; let elementToModifyElement = document.querySelector(elementToModify); let formattedName = SelectorTheEnglishNameOfTheProduct.replace(/(?:^|_)(\w)/g, (match, p1) => p1.toUpperCase()).replace(/_/g, '').replace(/(\w)([A-Z])/g, '$1 $2'); formattedName = formattedName.charAt(0).toUpperCase() + formattedName.slice(1); // 将首字母大写 // 如果该行已经插入过内容则跳过,判断条件为 被插入了 " | " if (elementToModifyElement.innerHTML.includes("|")) { continue; // 包含 "|" } else { // 执行插入语句 (function (index) { // 在这里执行你想要的修改操作,例如: elementToModifyElement.innerHTML = elementToModifyElement.innerHTML + " | " + "( " + formattedName + " )"; // 从图片alt里面获取中文 let imgPath = `#panel > section.user__profile.content--UwhYJ.grow--Q24fj > div.content__body--qkyqR.flex--root > div.container > div.order__content--ORU7n > div.sellOrders--nsRSO.listingSell > div.infinite-scroll > div > div:nth-child(${i + 1}) > div.order-own__item-icon--aCi6u > a > img`; // 需要确保选择的是 img 元素 let generalMerchandisePictureElements = document.querySelector(imgPath); console.log('图片元素:', generalMerchandisePictureElements); let imgAlt = generalMerchandisePictureElements ? generalMerchandisePictureElements.alt : null; // 调试输出 console.log('图片alt:', imgAlt); // 写个复制按钮。方便复制名称 const button = document.createElement('button'); button.className = "btn btn__light--c9XBJ"; button.tabIndex = 0; button.type = "button"; button.innerHTML = `