日期:2014-05-16  浏览次数:20471 次

在HTA窗口显示前调整其尺寸的方法 | #hta #javascript
    写过HTA的朋友大概都知道,初始时调整HTA窗口大小时,窗口先会显示为默认大小,再调整到目标大小,这将导致有一个闪烁,很碍眼,试过很多方法,最终找到了一种比较完美的解决方案。

    其实关键在于HTA标签,当解析到HTA标签时,才会对应用程序窗口进行渲染,所以在这之前调整大小,就会避免出现“一闪”的情况,不过这样做有个弊端,有些时候在HTA标签之前使用js对窗口进行操作可能会抛出异常,导致窗口调整失败(Access Denied),可能一些组件加载之前不允许对窗口进行操作。

   对于Access Denied,我们只要在执行它时捕获异常,如果发生的异常,就再执行一次,直到不再抛出异常即可。

示例代码:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
<title>Demo</title>
<script type="text/javascript">
while (true) {
    try {
	var w = 400, h = 300;
        window.resizeTo(w, h);
        window.moveTo((window.screen.width - w) / 2, (window.screen.height - h) / 2);
        break;
    } catch (e) { continue; }
}
</script>
<HTA:APPLICATION ID="app"
	APPLICATIONNAME="monster" 
	BORDER="dialog"
	MAXIMIZEBUTTON="no"
	SCROLLFLAT="yes"
	CAPTION="yes"
	INNERBORDER="no"
	ICON=""
	SCROLL="no"
	SHOWINTASKBAR="yes"
	SINGLEINSTANCE="yes"
	SYSMENU="yes"
	WINDOWSTATE="normal" />
<head>
<body>
It works!
</body>
</html>