需要准备的材料分别是:电脑、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