// ==UserScript== // @name 方正教务快速查询绩点 // @namespace http://tampermonkey.net/ // @version 2024-03-03 // @description 快速在方正教务系统查询绩点 // @author 张瑾涵 // @match https://jwgl.cug.edu.cn/jwglxt/cjcx/* // @icon  // @grant GM_addElement // @run-at document-idle // @license MIT // @downloadURL https://update.greasyfork.icu/scripts/489038/%E6%96%B9%E6%AD%A3%E6%95%99%E5%8A%A1%E5%BF%AB%E9%80%9F%E6%9F%A5%E8%AF%A2%E7%BB%A9%E7%82%B9.user.js // @updateURL https://update.greasyfork.icu/scripts/489038/%E6%96%B9%E6%AD%A3%E6%95%99%E5%8A%A1%E5%BF%AB%E9%80%9F%E6%9F%A5%E8%AF%A2%E7%BB%A9%E7%82%B9.meta.js // ==/UserScript== (function() { 'use strict'; // BEGIN添加文本提示 // 创建一个 span 元素 var newSpan = document.createElement('span'); newSpan.textContent = 'GPA计算方法:先选择对应的学年和学期,再点击查询,然后点击GPA按钮即可计算。'; // 设置新的文本内容 // 找到目标 label 元素 var labelElement = document.querySelector('.col-sm-12.control-label.align-left'); // 创建一个包含换行的文本节点 var lineBreakNode = document.createElement('br'); // 将空格和换行插入到目标元素中 labelElement.appendChild(lineBreakNode); // 将新的 span 元素添加到 label 中 labelElement.appendChild(newSpan); // END添加文本提示 // BEGIN修改下拉框默认值 var selectElement = document.querySelector('.ui-pg-selbox'); // 模拟点击下拉框 selectElement.click(); // 设置要选中的值 var valueToSelect = '100'; // 遍历下拉框中的选项并选中指定的值 var options = selectElement.options; for (var i = 0; i < options.length; i++) { if (options[i].value === valueToSelect) { options[i].selected = true; break; } } // 触发 change 事件以模拟选中 selectElement.dispatchEvent(new Event('change')); // END修改下拉框默认值 // 创建一个按钮元素 var button = document.createElement('button'); // button.innerHTML = 'GPA计算'; // 设置按钮文本 // 创建一个包含文本的 span 元素 var buttonText = document.createElement('span'); buttonText.textContent = 'GPA = NaN'; // 设置按钮文本内容 // 设置文本大小的样式 buttonText.style.fontSize = '10px'; // 设置文本大小为 16 像素 // 将包含文本的 span 元素添加到按钮中 button.appendChild(buttonText); button.className = 'btn btn-primary btn-sm'; // 找到目标元素 var targetElement = document.querySelector('.col-md-4.col-sm-5'); // 将按钮添加到目标元素中 targetElement.appendChild(button); button.addEventListener('click', function() { // 在按钮被点击时执行的操作 console.log('按钮被点击了!'); var pointSum = 0; var creditSum = 0; console.log(document); // 查找所有具有 aria-describedby="tabGrid_cj" 属性的元素 var elements = document.querySelectorAll('td[aria-describedby=tabGrid_xf]'); // 存储元素内容的数组 var dataArray = []; // 遍历每个匹配的元素,并将内容添加到数组中 elements.forEach(function(element) { var titleValue = element.textContent; var trElement = element.parentNode; // 获取上一层