JS中如何判断一元素是否获得焦点?

JavaScript031

JS中如何判断一元素是否获得焦点?,第1张

需要准备的材料分别是:电脑、html编辑器、浏览器。

1、首先,打开html编辑器,新建html文件,例如:index.html。

2、在index.html的<script>标签中,输入js代码:

$('body').append(document.activeElement.id == "a" ? 'true': 'false')

$('#a').focus(function () {

$('body').append(document.activeElement.id == "a" ? 'true': 'false')

})

3、浏览器运行index.html页面,此时会发现false代表没有聚焦,点击聚焦后发现打印了true。

js我的focus获得焦点无效,是参数设置错误造成的,解决方法如下:

1、首先新建一个html文件,创建a标签和两个按钮。

2、然后创建js函数getfocus()。

3、函数获取a标签的焦点。

4、创建js函数losefocus()。

5、函数内容为失去焦点,为按钮添加点击事件触发函数。

6、最后预览效果如图,当点击获取焦点按钮a标签获取焦点,点击失去焦点,焦点消失。

<head>

<meta charset="UTF-8">

<title>无缝滚动</title>

<style type="text/css">

body,ul,li{margin:0padding:0}

ul{list-style:none}

.slide{

width:500px

height:100px

border:1px solid #ddd

margin:20px auto 0

position:relative

overflow:hidden

}

.slide ul{

position:absolute/*相对于slide进行绝对定位*/

width:1000px/*比slide宽度大一倍,做这种连续滚动效果的时候,要在后面把内容复制一份*/

height:100px

left:0/*可以改变该值让其动起来*/

top:0

}

.slide ul li{

width:90px

height:90px

margin:5px

background-color:#ccc

line-height:90px

text-align: center

font-size:30px

float:left

}

.btns{

width:500px

height:50px

margin:10px auto 0

}

</style>

<script type="text/javascript" src="../js/jquery-1.12.4.min.js"></script>

<script type="text/javascript">

$(function(){

var $ul = $('#slide ul')

var left = 0

var deraction = 2//每次滚动的距离

//内容为两套li

$ul.html($ul.html() + $ul.html())

//反复循环定时器,30ms动一下可以看起来比较平滑

var timer = setInterval(move, 30)

function move(){

left -= deraction

//当第2套li完全显示出来的时候,整个移回原点重新移动,实现向左连续滚动

if(left <-500){

left = 0

}

//瞬间跳回,实现向右连续滚动

if(left >0){

left = -500

}

$ul.css({left: left})

}

$('#btn1').click(function() {

deraction = 2

})

$('#btn2').click(function() {

deraction = -2

})

$('#slide').mouseover(function() {

clearInterval(timer)

})

$('#slide').mouseout(function() {

timer = setInterval(move,30)

})

})

</script>

</head>

<body>

<div class="btns">

<input type="button" name="" value="向左" id="btn1">

<input type="button" name="" value="向右" id="btn2">

</div>

<div class="slide" id="slide">

<ul>

<li>1</li>

<li>2</li>

<li>3</li>

<li>4</li>

<li>5</li>

</ul>

</div>

</body>

鼠标移入要做的事情mouseover

鼠标移出要做的事情mouseout

<head>

    <meta charset="UTF-8">

    <title>鼠标移入移出</title>

    <style type="text/css">

        .box{

            width: 200px

            height: 200px

            background-color: gold

            margin: 100px auto 0

        }

        .son{

                width: 100px

                height: 100px

                background-color: green

        }

    </style>

    <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>

    <script type="text/javascript">

         $(function(){

        /*进入子元素也触发*/

        /*$('#div1').mouseover(function() {

        $(this).animate({marginTop: 50})//.stop()

        })

        $('#div1').mouseout(function() {

        $(this).animate({marginTop: 100})//.stop()

    })*/

        /*进入子元素不触发*/

        /*$('#div1').mouseenter(function() {

        $(this).stop().animate({marginTop: 50})//

        })

        $('#div1').mouseleave(function() {

        $(this).stop().animate({marginTop: 100})//

        })*/

        /*通过hover(mouseenter+mouseleave)实现简写*/

        $('#div1').hover(function() {

        $(this).stop().animate({marginTop: 50})

        }, function() {

        $(this).stop().animate({marginTop: 100})

            })

        })

    </script>

</head>

<body>

        <div id="div1" class="box">

                <div class="son"></div>

        </div>

</body>

创建一个子元素 促使鼠标移入到子元素才能移动

是由于时间mouse影响

则要使用mouseenter和mouseleave进行改变

也可以运用hover简化

autofocus

表单元素的值发生变化

<head>

                <meta charset="UTF-8">

                <title>input框事件</title>

                <style type="text/css">

                </style>

                <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>

                <script type="text/javascript">

                     $(function(){

                    // //一开始就获取焦点,相当于设置了autofocus自动获取焦点了(HTML5 新增表单控件属性)

                    // $('#txt01').focus()

                    // //文本框获取焦点的时候(有光标闪烁的时候)

                    // $('#txt01').focus(function() {

                    // alert('focus')

                    // })

                    // //失去焦点的时候(光标离开的时候)

                    // $('#txt01').blur(function() {

                    // alert('blur')

                    // })

                    // //输入框内容发生变化的时候,失去焦点后触发,可用于注册时验证用户名是否已存在

                    // $('#txt01').change(function() {

                    // alert('change')

                    // })

                    //松开键盘按键就触发

                    $('#txt01').keyup(function() {

                    alert('keyup')

                    })

                })

                </script>

</head>

<body>

        <input type="text" id="txt01">

</body>

<head>

            <meta charset="UTF-8">

            <title>jQuery其他事件</title>

            <style type="text/css">

            </style>

            <script type="text/javascript" src="js/jquery-1.12.4.min.js"></script>

            <script type="text/javascript">

            // // JS原生写法

            // window.onload = function(){

            // }

            // / /jQuery写法,等同于上面写法

            // $(window).load(function(){

            // })

            // //ready的写法

            // $(document).ready(function(){

            // })

            // //ready的简写

            // $(function(){

            // })

            // 窗口改变尺寸的时候,会高频触发

            $(window).resize(function() {

            console.log('3')

            })

            </script>

</head>

<body>

            <div id="div1"></div>

</body>

鼠标移入要做的事情mouseover

鼠标移出要做的事情mouseout