在HTA窗口展示前调整其尺寸的方法 | #hta #javascript
在HTA窗口显示前调整其尺寸的方法 | #hta #javascript
写过HTA的朋友大概都知道,初始时调整HTA窗口大小时,窗口先会显示为默认大小,再调整到目标大小,这将导致有一个闪烁,很碍眼,试过很多方法,最终找到了一种比较完美的解决方案。
其实关键在于HTA标签,当解析到HTA标签时,才会对应用程序窗口进行渲染,所以在这之前调整大小,就会避免出现“一闪”的情况,不过这样做有个弊端,有些时候在HTA标签之前使用js对窗口进行操作可能会抛出异常,导致窗口调整失败(Access Denied),可能一些组件加载之前不允许对窗口进行操作。
对于Access Denied,我们只要在执行它时捕获异常,如果发生的异常,就再执行一次,直到不再抛出异常即可。
示例代码:
写过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>