如何将 data-url 动态注入 href 实现中键点击新标签页打开 本文介绍一种基于 Tampermonkey 的轻量级解决方案,通过 Ja vaScript 自动提取 标签中的 data-url 值并写入 href 属性,使原本禁用中键点击的链接恢复「Ctrl+左键」或鼠标中键在新标签页打开的

本文介绍一种基于 Tampermonkey 的轻量级解决方案,通过 Ja vaScript 自动提取 标签中的 data-url 值并写入 href 属性,使原本禁用中键点击的链接恢复「Ctrl+左键」或鼠标中键在新标签页打开的功能。
如果你经常在一些教育平台(比如 K12 Learning、D2L Brightspace)上浏览,可能会遇到一个不大不小的麻烦:页面上的链接,用鼠标中键点不开,按住 Ctrl 再点左键也没反应。这背后的原因,往往是开发者为了前端路由或跳转控制,把 标签的 href 属性设置成了 “#”,而把真实的跳转地址藏在了 data-url 里。这种写法方便了 Ja vaScript 控制跳转逻辑,却牺牲了浏览器的原生交互体验——用户那些习以为常的快捷操作,比如中键点击、右键“在新标签页中打开”,全都失效了。
长期稳定更新的攒劲资源: >>>点此立即查看<<<
那么,有没有办法在不修改网站源码的前提下,优雅地解决这个问题呢?答案是肯定的。解决思路其实很直接:把 data-url 里藏着的真实 URL 解析出来,动态地写回到 href 属性里去。这样一来,链接的原生行为就恢复了,同时原有的语义和可访问性信息(比如 aria-label、title)也不会受到影响。下面就是一个稳定、可复用的 Tampermonkey 用户脚本,帮你一键搞定。
// ==UserScript==
// @name Fix Middle-Click Links (K12/D2L)
// @namespace https://github.com/user/scripts
// @version 1.1
// @description Restore middle-click & new-tab support by injecting data-url into href
// @author You
// @match *://*.k12.com/*
// @match *://*.brightspace.com/*
// @match *://*/d2l/*
// @grant none
// ==/UserScript==
(function () {
'use strict';
function updateLinks() {
document.querySelectorAll('a[data-url]').forEach(a => {
const dataUrl = a.dataset.url;
// 仅处理符合重定向模式的 data-url(如 /k12/redirect?url=...)
if (dataUrl && dataUrl.startsWith('/k12/redirect?url=')) {
try {
const rawTarget = dataUrl.substring('/k12/redirect?url='.length);
const decodedUrl = decodeURIComponent(rawTarget);
// 安全校验:确保是合法 HTTP(S) URL,避免 XSS 风险
if (/^https?:\/\//.test(decodedUrl)) {
a.href = decodedUrl;
}
} catch (e) {
console.warn('Failed to decode data-url:', dataUrl, e);
}
}
// 可选:支持其他重定向格式(如 D2L 的 /d2l/le/... 或 base64 编码)
else if (dataUrl && /^https?:\/\//.test(dataUrl)) {
a.href = dataUrl;
}
});
}
// 页面加载完成后立即执行一次
updateLinks();
// 监听 DOM 变化(更优雅替代 setInterval)
const observer = new MutationObserver(() => {
updateLinks();
});
observer.observe(document.body, {
childList: true,
subtree: true
});
// 可选:为单页应用(SPA)补充 hashchange 和 popstate 监听
window.addEventListener('hashchange', updateLinks);
window.addEventListener('popstate', updateLinks);
})();
这个脚本可不是简单的“查找-替换”,里面有几个关键设计,确保了它的高效与安全:
当然,在部署和使用时,还有几个细节需要留意:
总的来说,通过这个轻量级的 Tampermonkey 方案,你无需安装臃肿的浏览器扩展,也无需请求网站管理员修改代码,就能一键恢复链接的原生交互能力。让鼠标中键和 Ctrl+点击重新变得高效,这才是浏览体验该有的样子。
侠游戏发布此文仅为了传递信息,不代表侠游戏网站认同其观点或证实其描述