有时候我想通过点击小图片然后使其放大,这样的效果我们是怎么通过JS实现的,下面我为大家讲述DOM和非DOM的解决方案:
主代码(除了JS部分):
图片库 - 锐客网
*{
padding: 0px;
margin: 0px;
}
a{
text-decoration:none;
}
h1{
text-align: center;
}
li{
float: left;
list-style: none;
}
Snapshots
-
文章图片
-
文章图片
-
文章图片
文章图片
Choose an image.
οnclick="showPic(this); return false; "中this指的是当前的对象,即a标签,ruturn false阻止默认行为被触发,即防止点开链接时将用户带到一个新窗口,使得用在“占位符"中打开图片,起到放大图片的效果。
DOM方案:
function showPic(whichPic){
var source = whichPic.getAttribute("href");
//whichPic代表一个元素节点,具体说指向某个图片的元素,getAttribute获得元素节点
var placeholder = document.getElementById("placeholder");
// placeholder.src = https://www.it610.com/article/source;
//与下面一行代码等价,同样可以改变元素属性
placeholder.setAttribute("src", source);
//setAttribute对placeholder元素的src属性进行刷新,将属性source值刷新到src里var text = whichPic.getAttribute("title");
//获取属性为title的元素
var description = document.getElementById("description");
//得到id是description的p元素,并把它保存到变量description里
description.firstChild.nodeValue = https://www.it610.com/article/text;
//把description对象的第一个叶子节点的nodeValu属性值设置为变量text的值
}
其实上面一段代码也可以简写如下,但由于怕自己一时无法理解,所以还是推荐上述的详细的写法:
function showPic(whichPic){
document.getElementById("placeholder").setAttribute("src", whichPic.getAttribute("href"));
}
通过setAttribute()函数把whichPic.getAttribute("href")从a标签里获得的href属性刷新到img标签里的src属性里,
简单来说setAttribute(attribute, value)实现的把一个属性里面的内容复制并粘贴到另一个属性里;
非DOM实现:
function showPic(whichPic){
var source = whichPic.getAttribute("href");
//whichPic代表一个元素节点,具体说指向某个图片的元素,getAttribute获得元素节点
var placeholder = document.getElementById("placeholder");
placeholder.src = https://www.it610.com/article/source;
//与上面的placeholder.setAttribute("src", source)等价
}
非DOM的方法可移植性不如DOM好,所以更喜欢用DOM的方法。
话不多说,我们看效果图:
【JS实现图片库】
推荐阅读
- JavaScript|JavaScript: BOM对象 和 DOM 对象的增删改查
- 前端|web前端dya07--ES6高级语法的转化&render&vue与webpack&export
- JS/JavaScript|JS/JavaScript CRC8多项式 16进制
- JS|VUE学习笔记[30-46]
- 腾讯TEG实习|腾讯实习——Vue解决跨域请求
- 地图|高德地图清除指定覆盖物 自定义覆盖物样式(完整dome)
- Pyecharts|Pyecharts 猎聘招聘数据可视化
- flex|C语言-使用goto语句从循环中跳出
- HTML+Js实战项目|在网页中实现icon小图标的几种方法
- js中国标准时间转化为年月日,时间戳