</head> <body> <h1>WinClose</h1> <p>关闭指定的窗口.</p> <pre class="Syntax"><span class="func">WinClose</span> <span class="optional">WinTitle, WinText, SecondsToWait, ExcludeTitle, ExcludeText</span></pre> <h2 id="Parameters">参数</h2> <dl> <dt>WinTitle, WinText, ExcludeTitle, ExcludeText</dt> <dd> <p>类型: <a href="../Concepts.htm#strings">字符串</a>, <a href="../Concepts.htm#numbers">整数</a>或<a href="../Concepts.htm#objects">对象</a></p> <p>如果这些都是空白或省略, 将使用<a href="../misc/WinTitle.htm#LastFoundWindow">上次找到的窗口</a>. 否则, 为 <em>WinTitle</em> 指定<a href="../misc/WinTitle.htm">窗口标题或其他条件</a>, 来标识目标窗口, 和/或为 <em>WinText</em> 指定目标窗口的单个文本元素的子字符串(由包含的 Window Spy 实用程序显示).</p> <p><em>ExcludeTitle</em> 和 <em>ExcludeText</em> 可用于根据标题或文本排除一个或多个窗口. 它们的规范类似于 <em>WinTitle</em> 和 <em>WinText</em>, 除了 <em>ExcludeTitle</em> 不识别除窗口标题之外的任何条件.</p> <p>窗口标题和文本是区分大小写的. 默认情况下, 不检测隐藏窗口, 而检测隐藏文本元素, 除非使用 <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a> 和 <a href="DetectHiddenText.htm">DetectHiddenText</a> 进行更改. 默认情况下, 窗口标题必须以指定的 <em>WinTitle</em> 或 <em>ExcludeTitle</em> 开头才能匹配, 除非使用 <a href="SetTitleMatchMode.htm">SetTitleMatchMode</a> 进行更改.</p> <dt>SecondsToWait</dt> <dd> <p>类型: <a href="../Concepts.htm#numbers">整数</a>或<a href="../Concepts.htm#numbers">浮点数</a></p> <p>如果省略, 此函数不会等待. 否则, 请指定秒数(可以为小数) 来等待窗口关闭. 如果窗口在此期间没有关闭, 那么脚本会继续执行.</p> </dd> </dl> <h2 id="Error_Handling">错误处理</h2> <p>如果找不到窗口, 则抛出 <a href="Error.htm#TargetError">TargetError</a>, 除非使用了 <a href="#group">group</a> 模式.</p> <p>如果找到了一个窗口但无法关闭, 则不会抛出异常, 因此, 如果你需要确定窗口已经关闭, 请使用 <a href="WinExist.htm">WinExist</a> 或 <a href="WinWaitClose.htm">WinWaitClose</a>.</p> <h2 id="Remarks">备注</h2> <p>此函数发送关闭消息到窗口. 结果取决于窗口(它可能会询问是否保存数据等).</p> <p>如果匹配窗口是活动的, 那么会优先关闭此窗口而不是其他匹配窗口. 一般而言, 如果有多个匹配窗口, 那么会关闭最上面的(最近使用的) 窗口.</p> <p id="group">此函数仅对单独一个窗口起作用, 除非 <em>WinTitle</em> 是 <a href="GroupAdd.htm">ahk_group GroupName</a>(没有其他指定条件), 在这种情况下, 组中的所有窗口均会受到影响.</p> <p>当函数处于等待状态时, 可以通过<a href="../Hotkeys.htm">热键</a>, <a href="Menu.htm">自定义菜单项</a>或<a href="SetTimer.htm">计时器</a>来启动新的<a href="../misc/Threads.htm">线程</a>.</p> <p>WinClose 发送 WM_CLOSE 消息到目标窗口, 这种关闭方法有些强制性. 关闭窗口的另一种方法是发送下面的消息. 它可能会产生与此命令不同的行为, 因为它类似于按下 <kbd>Alt</kbd>+<kbd>F4</kbd> 或点击窗口标题栏的关闭按钮的效果:</p> <pre>PostMessage 0x112, 0xF060,,, <i>WinTitle</i>, <i>WinText</i> <em>; 0x112 = WM_SYSCOMMAND, 0xF060 = SC_CLOSE</em></pre> <p>如果使用 WinClose 无法关闭窗口, 那么您可以使用 <a href="WinKill.htm">WinKill</a> 来强制关闭.</p> <h2 id="Related">相关</h2> <p><a href="WinKill.htm">WinKill</a>, <a href="WinWaitClose.htm">WinWaitClose</a>, <a href="ProcessClose.htm">ProcessClose</a>, <a href="WinActivate.htm">WinActivate</a>, <a href="SetTitleMatchMode.htm">SetTitleMatchMode</a>, <a href="DetectHiddenWindows.htm">DetectHiddenWindows</a>, <a href="../misc/WinTitle.htm#LastFoundWindow">Last Found Window</a>, <a href="WinExist.htm">WinExist</a>, <a href="WinActive.htm">WinActive</a>, <a href="WinWaitActive.htm">WinWaitActive</a>, <a href="WinWait.htm">WinWait</a>, <a href="GroupActivate.htm">GroupActivate</a></p> <h2 id="Examples">示例</h2> <div class="ex" id="ExBasic"> <p><a class="ex_number" href="#ExBasic"></a> 如果记事本确实存在, 关闭它, 否则关闭计算器.</p> <pre>if WinExist("Untitled - Notepad") WinClose <em>; 使用由 WinExist 找到的窗口</em> else WinClose "Calculator"</pre> </div> </body> </html>