当前位置:
首页 > temp > JavaScript教程 >
-
JavaScript连载33-点击查看大图效果以及闭包初步
一、点击图片显示大图代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>D33_1_SwitchIcon</title>
<style>
#box{
border:1px solid #cccccc;
width:360px;
height:70px;
padding-top:360px;
margin:100px auto;
background:url("img/img_05.png") no-repeat;
}
ul{
display:flex;
justify-content:center;
align-items: center;
cursor:pointer;
list-style: none;
}
img{
width: 250px;
}
</style>
</head>
<body>
<div id="box">
<ul>
<li id="li01"><img src="img/img_01.png" alt=""></li>
<li id="li02"><img src="img/img_02.png" alt=""></li>
<li id="li03"><img src="img/img_03.png" alt=""></li>
<li id="li04"><img src="img/img_04.png" alt=""></li>
<li id="li05"><img src="img/img_05.png" alt=""></li>
</ul>
</div>
<script>
window.onload=function (ev) {
//1.获取标签
// var li01 = document.getElementById("li01");
// var li02 = document.getElementById("li02");
// var li03 = document.getElementById("li03");
// var li04 = document.getElementById("li04");
// var li05 = document.getElementById("li05");
// var box = document.getElementById("box");
//上面的语句我们使用函数来封装起来
var li01 = $("li01");
var li02 = $("li02");
var li03 = $("li03");
var li04 = $("li04");
var li05 = $("li05");
var box = $("box");
//2.监听鼠标事件
// li01.onmouseover = function (ev1) {
// box.style.background = 'url("img/img_01.png") no-repeat';
// };
// li02.onmouseover = function (ev2) {
// box.style.background = 'url("img/img_02.png") no-repeat';
// };
// li03.onmouseover = function (ev3) {
// box.style.background = 'url("img/img_03.png") no-repeat';
// };
// li04.onmouseover = function (ev4) {
// box.style.background = 'url("img/img_04.png") no-repeat';
// };
// li05.onmouseover = function (ev5) {
// box.style.background = 'url("img/img_05.png") no-repeat';
// };
li01.onmouseover = function (ev1) {
changeImg("img/img_01.png")
};
li02.onmouseover = function (ev1) {
changeImg("img/img_02.png")
};
li03.onmouseover = function (ev1) {
changeImg("img/img_03.png")
};
li04.onmouseover = function (ev1) {
changeImg("img/img_04.png")
};
li05.onmouseover = function (ev1) {
changeImg("img/img_05.png")
};
//这样我们定义了鼠标的显示情况就可以来展示大图了
//接下来我们封装函数,有大批量的重复代码
}
/**
* 根据id获取标签
* @param [string} id
*/
function $(id) { //$
return typeof id === 'string'? document.getElementById(id):null;
}
/**
*
* @param {string}tag
* @param {string}imgSrc
*/
function changeImg(imgSrc) {
box.style.background = 'url("'+ imgSrc + '") no-repeat';
}
</script>
</body>
</html>
二、如果使用闭包也可达到上面的效果
window.onload = function (ev6) {
//1.获取需要的标签
var box = document.getElementById("box");
var allList = box.getElementsByTagName("li");
//2.监听鼠标进入li标签
for(var i=0;i<allList.length;i++){
//2.1取出单独的li标签
var sLi = allList[i];
// sLi.setAttribute("index",i+1);//复习设置属性的方法setAttribute
// sLi.onmouseover = function (ev7) {
// console.log(this);
// console.log(this.getAttribute("index"));//获取这个li的index值
// }
//上面五行等价去下面,使用了闭包的知识,下次连载我们再讲
(function (tag) {
sLi.onmouseover = function (ev9) {//复习onmouseover就是鼠标滑过这个模块之后要干的活儿
console.log(tag);
box.style.background = 'url("img/img_0'+ tag + '.png") no-repeat';
}
})(i+1)
}
}
三、源码:
- D33_1_SwitchIcon.html
- D32_2_CommonMouse.html
- D32_3_erweimaXianshi.html
-
地址:
https://github.com/ruigege66/JavaScript/blob/master/D33_1_SwitchIcon.html
-
https://github.com/ruigege66/JavaScript/blob/master/D32_2_CommonMouse.html
-
https://github.com/ruigege66/JavaScript/blob/master/D32_3_erweimaXianshi.html
-
博客园:
https://www.cnblogs.com/ruigege0000/
-
CSDN:
https://blog.csdn.net/weixin_44630050?t=1
出处:https://www.cnblogs.com/ruigege0000/p/13698297.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数