- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试改编的Javascript根本不起作用。如何让它发挥作用?
问题:在我的工作场所,我们有很多超链接,我必须单击它们才能打开票号。但所有票号都超链接到一个新网站,该网站速度非常慢,而且我看不到该问题得到解决。有一个旧网站,速度非常快,我希望超链接只将我引导到那里。
例如链接引导我前往
https://companysachinperf.com/newweb/TicketDetnumber.jspx?tNumber=7-12345
但我希望每当我点击它时它都会引导我到一个新链接 https://oldwebe.company.com/xyz/Ticketnumber.jspx?tNumber=7-12345
注意:
1.两个网站的底层数据库是相同的。
2.company.com 和 oldwebe.comapny 仅用于说明目的。
3.7-12345 是我的示例中的票号,但在给定的 html 页面上可能有很多这样的票,一旦我单击其中任何一个,旧网站就会打开该票号。
4.这是我第一次开始用 Javascript 编码。
尝试的解决方案(不起作用)。我将此脚本放入 Tamper Monkey
var href = "https://companysachinperf.com/newweb/TicketDetnumber.jspx?tNumber=7-12345"
var oldWebsiteLink = "https://oldwebe.company.com/xyz/Ticketnumber.jspx?tNumber=@id"
var elems = document.querySelectorAll('.comp-link');
for (var i=elems.length; i--;) {
elems[i].addEventListener('click', function(e) {
e.preventDefault();
var hrefVal = this.getAttribute('href');
var id = hrefVal.substr(hrefVal.lastIndexOf('/') + 1);
var newLink = oldWebsiteLink.replace("@id", id);
console.log(newLink);
window.open(newLink,'_blank');
}, false);
}
最佳答案
一种方法如下:
// here we use the Arrow syntax form of an Immediately-Invoked Function
// Expression ('IIFE'); this function is encountered and then immediately
// invoked by the browser:
// (function(){ /*...code...*/ })() or
// (()=>{ /*...code...*/})()
(() => {
// using document.querySelectorAll('a') to retrieve a NodeList
// of all <a> elements in the document, and passing that
// NodeList to Array.from() in order to use Array methods
// on the discovered Nodes:
let links = Array.from(document.querySelectorAll('a')),
// the new path we want to create:
newPath = '/xyz/Ticketnumber.jspx';
// here we filter the links Array, again using an Arrow function:
links.filter(
// the first argument of the Array.prototype.filter() method
// is always a reference to the current array-element of the
// Array (here it's named 'anchor'); and this is passed into
// the function:
(anchor) => {
// if the anchor.hostname is exactly-equal to the supplied
// String:
if (anchor.hostname === 'companysachinperf.com') {
// we update/set the 'data-oldhref' attribute of the
// current <a> element to the current value of the href
// attribute (this is for demonstration purposes in the
// demo, and is irrelevant to the performance/functionality;
// it can be removed:
anchor.dataset.oldhref = anchor.href;
// we update the <a> element's hostname property to the
// value of the supplied String:
anchor.hostname = 'oldwebe.company.com';
// we update the path to the new path:
anchor.pathname = newPath;
}
})
// here we close the function statement, the parentheses that follow
// the function (the '()') can contain any arguments you wish to supply
// and those arguments will be available to the function; however they
// would need to be declared within the opening parentheses of the
// Arrow function:
/* ((argumentA,argumentB) => {
...code...
})(document.body,somethingElse);
*/
})();
(() => {
let links = Array.from(document.querySelectorAll('a')),
newPath = '/xyz/Ticketnumber.jspx';
links.filter(
(anchor) => {
if (anchor.hostname === 'companysachinperf.com') {
anchor.dataset.oldhref = anchor.href;
anchor.hostname = 'oldwebe.company.com';
anchor.pathname = newPath;
}
})
})();
/*
irrelevant to the functionality and for demo purposes only:
*/
a::before {
content: attr(href);
}
a::after {
display: block;
content: '\A(Used to be: ' attr(data-oldhref) ')';
}
<a href="https://companysachinperf.com/newweb/TicketDetnumber.jspx?tNumber=7-12345" data-oldhref=""></a>
要将功能包装到 Tampermonkey 脚本中,请使用我自己安装的 Tampermonkey:
// ==UserScript==
// @name Modifying links
// @namespace http://tampermonkey.net/
// @version 0.1
// @description Modifying links from one hostname to another
// @author David Thomas: https://stackoverflow.com/a/53693814/82548
// @match https://companysachinperf.com
// @grant none
// ==/UserScript==
(function() {
'use strict';
(() => {
let links = Array.from(document.querySelectorAll('a')),
newPath = '/xyz/Ticketnumber.jspx';
links.filter(
(anchor) => {
if (anchor.hostname === 'companysachinperf.com') {
anchor.dataset.oldhref = anchor.href;
anchor.hostname = 'oldwebe.company.com';
anchor.pathname = newPath;
}
})
})();
})();
来自您的comment在问题下方:
How to adapt the code that you provided to be flexible for any ticket number. Currently it is hardcoded for 7-12345. ...How to put all the html+css+js code all in [Tampermonkey]?
不,你错了,只有一个 <a>
演示中的元素,如果您查看代码票号,tNumber=12345
除了 <a>
之外,绝对不会以任何方式修改或编码。元素的href
属性;提供的代码(假设链接格式与您的描述匹配)将适用于任何票号,因为脚本将保持不变。
至于将 HTML 添加到 Tampermonkey:你不需要; Tampermonkey 脚本对它在相关页面中找到的 HTML 进行操作(您可以使用 Tampermonkey 脚本中的 // @match http://*/*
行来确定)。
至于使用 Tampermonkey 将 CSS 添加到页面,这很简单,例如:
// ==UserScript==
// @name Adding Style demo
// @namespace http://tampermonkey.net/
// @version 0.1
// @description try to take over the world with garish color choices
// @author David Thomas: https://stackoverflow.com/a/53693814/82548
// @match https://stackoverflow.com/*
// @grant none
// ==/UserScript==
(function() {
'use strict';
// create a <style> element:
let style = document.createElement('style'),
// find the <head> element:
head = document.querySelector('head'),
// define a CSS Selector:
importantElements = 'h1 > a',
// define a CSS property-value (note that
// using '!important' - which ordinarily
// shouldn't be used is used here because
// I couldn't be bothered to increase the
// specificity of the 'importantElement'
// selector):
importantColor = '#f00 !important';
// assign an id to the created <style> element:
style.id = 'TampermonkeyInsertedStyleElement';
// update the text-content of the <style> element
// using a template literal (delimited by backticks),
// in which newlines don't require escaping and in which
// JavaScript variables can be interpolated:
style.textContent = `
body { background-color: #f908; }
${importantElements} {color: ${importantColor};}`;
// appending the created <style> element to the <head>:
head.appendChild(style);
})();
引用文献:
Array.from()
.Array.prototype.filter()
document.links
.document.querySelector()
.document.querySelectorAll()
.HTMLAnchorElement
.HTMLElement.dataset
.HTMLHyperLinkElementUtils.pathname
.HTMLHyperLinkElementUtils.hostname
.Node.appendChild()
.引用书目:
关于用于动态更改超链接的 JavaScript 无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53681319/
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
var urlsearch = "http://192.168.10.113:8080/collective-intellegence/StoreClicks?userid=" + userId +
我有一个非常奇怪的问题,过去两天一直让我抓狂。 我有一个我试图控制的串行设备(LS 100 光度计)。使用设置了正确参数的终端(白蚁),我可以发送命令(“MES”),然后是定界符(CR LF),然后我
我目前正试图让无需注册的 COM 使用 Excel 作为客户端,使用 .NET dll 作为服务器。目前,我只是试图让概念验证工作,但遇到了麻烦。 显然,当我使用 Excel 时,我不能简单地使用与可
我开发了简单的 REST API - https://github.com/pavelpetrcz/MandaysFigu - 我的问题是在本地主机上,WildFly 16 服务器的应用程序运行正常。
我遇到了奇怪的情况 - 从 Django shell 创建一些 Mongoengine 对象是成功的,但是从 Django View 创建相同的对象看起来成功,但 MongoDB 中没有出现任何数据。
我是 flask 的新手,只编写了一个相当简单的网络应用程序——没有数据库,只是一个航类搜索 API 的前端。一切正常,但为了提高我的技能,我正在尝试使用应用程序工厂和蓝图重构我的代码。让它与 pus
我的谷歌分析 JavaScript 事件在开发者控制台中运行得很好。 但是当从外部 js 文件包含在页面上时,它们根本不起作用。由于某种原因。 例如; 下面的内容将在包含在控制台中时运行。但当包含在单
这是一本名为“Node.js 8 the Right Way”的书中的任务。你可以在下面看到它: 这是我的解决方案: 'use strict'; const zmq = require('zeromq
我正在阅读文本行,并创建其独特单词的列表(在将它们小写之后)。我可以使它与 flatMap 一起工作,但不能使它与 map 的“子”流一起工作。 flatMap 看起来更简洁和“更好”,但为什么 di
我正在编写一些 PowerShell 脚本来进行一些构建自动化。我发现 here echo $? 根据前面的语句返回真或假。我刚刚发现 echo 是 Write-Output 的别名。 写主机 $?
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我将一个工作 View Controller 类从另一个项目复制到一个新项目中。我无法在新项目中加载 View 。在旧项目中我使用了presentModalViewController。在新版本中,我
我对 javascript 很陌生,所以很难看出我哪里出错了。由于某种原因,我的功能无法正常工作。任何帮助,将不胜感激。我尝试在外部 js 文件、头部/主体中使用它们,但似乎没有任何效果。错误要么出在
我正在尝试学习Flutter中的复选框。 问题是,当我想在Scaffold(body :)中使用复选框时,它正在工作。但我想在不同的地方使用它,例如ListView中的项目。 return Cente
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我有一个组合框,其中包含一个项目,比如“a”。我想调用该组合框的 Action 监听器,仅在手动选择项目“a”完成时才调用。我也尝试过 ItemStateChanged,但它的工作原理与 Action
你能看一下照片吗?现在,一步前我执行了 this.interrupt()。您可以看到 this.isInterrupted() 为 false。我仔细观察——“这个”没有改变。它具有相同的 ID (1
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我正在尝试在我的网站上设置一个联系表单,当有人点击发送时,就会运行一个作业,并在该作业中向所有管理员用户发送通知。不过,我在失败的工作表中不断收到此错误: Illuminate\Database\El
我是一名优秀的程序员,十分优秀!