通过命令行指定参数跳转到HTA文件中的锚点
Jump to anchor in HTA file by command line specified parameter
有HTA格式的cmd脚本帮助文件,每次用户通过脚本按'h/H'键都会打开。想要 HTA 通过上下文从调用帮助的地方跳转到它的特定部分(在 windows 帮助文件中通常如此),但不知道如何去做。考虑将锚名称作为 mshta.exe 的参数传递,而不是在 HTA 文件的开头处理...
标准 HTML 定义的锚点在我的情况下不起作用(也许这在 HTA 中根本不起作用??),但找到了可行的 javascript 方法。
<head>
<script type="text/javascript">
function spoil(id){
if (document.getElementById) {
var divid = document.getElementById(id);
divid.style.display = (divid.style.display = 'block');
window.location = '#' + id;
}
}
</script>
</head>
<body onload="spoil('anchor_name')";>
也找到了 a way how to read passed parameters of mshta.exe,但它在 VBS 中,我不知道如何将变量从 VBS 传输到 javascript。
任何人都可以帮助我制作不同的语言脚本来协作或提出其他方法来实现 %subj%
关于跳转锚点:
对我来说,常规方法就可以了。我尝试了 window.location = '#stuff'
、window.location.href = '#stuff'
和 window.location.hash = '#stuff'
,所有这些都达到了预期的效果。
关于阅读命令行:
您应该能够使用链接教程中描述的相同机制 - 给 <hta:application>
标签一个 id
然后在 JavaScript 中引用它并阅读它的 commandLine
属性:
<html>
<head>
<title>Test</title>
<hta:application id="htaApp" applicationname="Test">
<script language="JScript">
window.onload = function () {
var htaApp = document.getElementById('htaApp')
document.getElementById('cmdLine').innerText = htaApp.commandLine
}
</script>
</head>
<body>
<p>Command line: <span id="cmdLine"></span></p>
</body>
</html>
在命令行中,您将整个内容作为字符串,如果您不知道“参数 0”(文件路径)在哪里结束以及“实际”参数从哪里开始,这可能会有问题,因为路径中可以有空格。
一种适用于您在野外遇到的所有情况的启发式方法是寻找 .hta
后跟一个可选的双引号,然后是字符串的结尾或一些空格,然后只查看该部分紧随其后。
var actualArgumentsPart = htaApp.commandLine.replace(/^.*?\.hta"?(\s+|$)/, '')
如果您愿意,您还可以将该部分拆分为空白的单独参数(尽管这会忽略参数中的引号 - 如果需要尊重引号,您需要 a function like this instead):
var individualArguments = actualArgumentsPart.split(/\s+/)
我认为这对你的情况来说甚至没有必要,所以你可以简单地这样做:
<html>
<head>
<title>Test</title>
<hta:application id="htaApp" applicationname="Test">
<script language="JScript">
window.onload = function () {
var htaApp = document.getElementById('htaApp')
var htaArguments = htaApp.commandLine.replace(/^.*?\.hta"?(\s+|$)/, '')
window.location.hash = '#' + htaArguments
}
</script>
</head>
<body>
This is an example!
<h1 id="first">First Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
<h1 id="second">Second Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
<h1 id="third">Third Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
</body>
</html>
如果你试试这个,你会发现你可以 mshta c:\path\to\file.hta third
跳到第三个 header 例如。
有HTA格式的cmd脚本帮助文件,每次用户通过脚本按'h/H'键都会打开。想要 HTA 通过上下文从调用帮助的地方跳转到它的特定部分(在 windows 帮助文件中通常如此),但不知道如何去做。考虑将锚名称作为 mshta.exe 的参数传递,而不是在 HTA 文件的开头处理...
标准 HTML 定义的锚点在我的情况下不起作用(也许这在 HTA 中根本不起作用??),但找到了可行的 javascript 方法。
<head>
<script type="text/javascript">
function spoil(id){
if (document.getElementById) {
var divid = document.getElementById(id);
divid.style.display = (divid.style.display = 'block');
window.location = '#' + id;
}
}
</script>
</head>
<body onload="spoil('anchor_name')";>
也找到了 a way how to read passed parameters of mshta.exe,但它在 VBS 中,我不知道如何将变量从 VBS 传输到 javascript。
任何人都可以帮助我制作不同的语言脚本来协作或提出其他方法来实现 %subj%
关于跳转锚点:
对我来说,常规方法就可以了。我尝试了 window.location = '#stuff'
、window.location.href = '#stuff'
和 window.location.hash = '#stuff'
,所有这些都达到了预期的效果。
关于阅读命令行:
您应该能够使用链接教程中描述的相同机制 - 给 <hta:application>
标签一个 id
然后在 JavaScript 中引用它并阅读它的 commandLine
属性:
<html>
<head>
<title>Test</title>
<hta:application id="htaApp" applicationname="Test">
<script language="JScript">
window.onload = function () {
var htaApp = document.getElementById('htaApp')
document.getElementById('cmdLine').innerText = htaApp.commandLine
}
</script>
</head>
<body>
<p>Command line: <span id="cmdLine"></span></p>
</body>
</html>
在命令行中,您将整个内容作为字符串,如果您不知道“参数 0”(文件路径)在哪里结束以及“实际”参数从哪里开始,这可能会有问题,因为路径中可以有空格。
一种适用于您在野外遇到的所有情况的启发式方法是寻找 .hta
后跟一个可选的双引号,然后是字符串的结尾或一些空格,然后只查看该部分紧随其后。
var actualArgumentsPart = htaApp.commandLine.replace(/^.*?\.hta"?(\s+|$)/, '')
如果您愿意,您还可以将该部分拆分为空白的单独参数(尽管这会忽略参数中的引号 - 如果需要尊重引号,您需要 a function like this instead):
var individualArguments = actualArgumentsPart.split(/\s+/)
我认为这对你的情况来说甚至没有必要,所以你可以简单地这样做:
<html>
<head>
<title>Test</title>
<hta:application id="htaApp" applicationname="Test">
<script language="JScript">
window.onload = function () {
var htaApp = document.getElementById('htaApp')
var htaArguments = htaApp.commandLine.replace(/^.*?\.hta"?(\s+|$)/, '')
window.location.hash = '#' + htaArguments
}
</script>
</head>
<body>
This is an example!
<h1 id="first">First Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
<h1 id="second">Second Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
<h1 id="third">Third Header</h1>
<script language="JScript">for (var i = 0; i < 1000; i++) document.write('Lorem Ipsum ');</script>
</body>
</html>
如果你试试这个,你会发现你可以 mshta c:\path\to\file.hta third
跳到第三个 header 例如。