Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/442.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何使用JavaScript模拟单击以使当前输入失去焦点_Javascript_Focus_Yui - Fatal编程技术网

如何使用JavaScript模拟单击以使当前输入失去焦点

如何使用JavaScript模拟单击以使当前输入失去焦点,javascript,focus,yui,Javascript,Focus,Yui,我有一个输入,在某些点上恰好有焦点。如果用户单击页面的“背景”,输入将失去焦点。我试图用下面的代码模拟背景上的点击,但这不起作用(你会注意到输入仍然有焦点)。有没有关于如何编写模拟点击页面“背景”的代码的建议 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <html xmlns="http:

我有一个输入,在某些点上恰好有焦点。如果用户单击页面的“背景”,输入将失去焦点。我试图用下面的代码模拟背景上的点击,但这不起作用(你会注意到输入仍然有焦点)。有没有关于如何编写模拟点击页面“背景”的代码的建议

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
        <script type="text/javascript" src="http://yui.yahooapis.com/2.6.0/build/yahoo/yahoo-min.js" ></script>
        <script type="text/javascript" src="http://yui.yahooapis.com/2.6.0/build/event/event-min.js" ></script>
        <script type="text/javascript">
            YAHOO.util.Event.onDOMReady(function() {
                document.getElementById("input").focus();    
                document.getElementById("main").focus();    
            });
        </script>
    </head>
    <body>
        <div id="main">
            <form action="/">
                <p>
                    <input type="text" id="input"/>
                </p>
            </form>
        </div>
    </body>
</html>

YAHOO.util.Event.onDOMReady(函数(){
document.getElementById(“输入”).focus();
document.getElementById(“main”).focus();
});


我想使用
blur()
可以实现以下目的:

<script type="text/javascript">
    YAHOO.util.Event.onDOMReady(function() {
        document.getElementById("input").focus();    
        document.getElementById("input").blur();    
    });
</script>

YAHOO.util.Event.onDOMReady(函数(){
document.getElementById(“输入”).focus();
document.getElementById(“输入”).blur();
});

尝试使用
blur
事件。如果使用jQuery,可以调用DOM对象来引发此事件。
blur()
方法在没有jQuery的情况下也应该可以工作


你的想法是对的,但有一个小问题

document.getElementById("main").focus();

<div id="main">
document.getElementById(“main”).focus();
如代码所示,实际上div HTMLElement没有焦点方法


因此,您可以调用具有焦点方法的其他元素,或者在输入元素上调用
blur()

oops,我没有注意到他的脚本引用。不管框架如何,blur()方法都能工作。非常好的东西,谢谢Paolo。我应该考虑一下:)。