html 图片左右键切换,js 点击上下左右键改变图片位置

今天看了dom的一些知识,巩固了一下js基础,突然想到自己想做一个小汽车移动的功能,所以二话不说,先来构思一下:首先我们找一张小汽车的图片,把它放在页面中,然后需要用到上下左右键交互,所以必须用到js中dom的知识了。

car

img{

width: 200px;

height: 200px;

position: absolute;

top: 300px;

left: 600px;

}

汽车

我为了让效果看的更加明显,把汽车放在了页面正中间。接下来就要写js了。首先我们必须明白,要让图片移动必须先选中图片,而且交互要交互在图片上,有些朋友在这时候可能会想,键盘事件一般发生在输入框之类当中,让图片响应键盘事件该怎么办。知识都是一点点理解实践起来的,所以我们在这里想象一下:我们如果拿到了图片,在图片上添加img.onkeyup会有用吗?这时候图片是肯定不会响应的,就相当于我不想唱歌,非让我唱,但是爸爸过来了,爸爸很严厉,他让我唱!我只能唱,所以我们干嘛不加到document上呢。选定document,里面的图片自然而然就选上了。看下面js:

window.onload = function(){

var img = document.getElementsByTagName('img')[0];

document.onkeyup = function(event){

if (event.keyCode==37) {

img.style.left = img.offsetLeft-20+"px";

}else if (event.keyCode==38){

img.style.top = img.offsetTop-20+"px";

}else if (event.keyCode==39){

img.style.left = img.offsetLeft+20+"px";

}else if (event.keyCode==40){

img.style.top = img.offsetTop+20+"px";

}

}

}

里面的37,38,39,40分别是左上右下的键值。这样我们就可以实现上下左右键移动图片了。

有一个知识点,就是offset:

offsetTop:以 CSS 像素为单位返回元素上边框距其 offsetParent 上边框的距离。

offsetLeft:以 CSS 像素为单位返回元素相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置。

这里最主要的是找准 offsetParent。

其实很简单,比如我们要计算A元素的 offsetTop, 那么先要找到A元素的offsetParent,A元素的offsetParent应该是离A元素最近的父元素,并且父元素设置了position:relative或absolute属性,如果没有匹配到任何父元素,那么应该以窗口为基准计算元素的offsetTop。

完整代码如下:

car

img{

width: 200px;

height: 200px;

position: absolute;

top: 300px;

left: 600px;

}

window.onload = function(){

var img = document.getElementsByTagName('img')[0];

document.onkeyup = function(event){

if (event.keyCode==37) {

img.style.left = img.offsetLeft-20+"px";

}else if (event.keyCode==38){

img.style.top = img.offsetTop-20+"px";

}else if (event.keyCode==39){

img.style.left = img.offsetLeft+20+"px";

}else if (event.keyCode==40){

img.style.top = img.offsetTop+20+"px";

}

}

}

汽车

有不正确的地方望大家指教,祝大家早日富可敌国,bye~

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用CSS3的transform属性来实现左右滑动切换图片。 首先,需要将图片放入一个容器中,设置容器的宽度为图片宽度的总和,设置overflow属性为hidden,这样就可以隐藏容器外部的图片。 然后,使用CSS3的transform属性来改变容器的位置,实现左右滑动的效果。可以使用translateX函数来改变容器的水平位置,例如translateX(-100%)表示向移动一个图片的宽度,translateX(100%)表示向右移动一个图片的宽度。 最后,使用JavaScript来实现触发左右滑动的事件,例如点击左右箭头按钮时,改变容器的位置即可。 以下是一个示例代码: HTML: ```html <div class="container"> <img src="image1.jpg"> <img src="image2.jpg"> <img src="image3.jpg"> </div> <button class="left-arrow">箭头</button> <button class="right-arrow">右箭头</button> ``` CSS: ```css .container { width: 300%; overflow: hidden; transition: transform 0.5s ease-in-out; } .container img { float: left; width: 33.33%; } .left-arrow, .right-arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 1; } .left-arrow { left: 10px; } .right-arrow { right: 10px; } ``` JavaScript: ```javascript var container = document.querySelector('.container'); var leftArrow = document.querySelector('.left-arrow'); var rightArrow = document.querySelector('.right-arrow'); var currentPosition = 0; // 当前容器的位置,初始值为0 leftArrow.addEventListener('click', function() { currentPosition += 100; // 向移动一个图片的宽度 container.style.transform = 'translateX(-' + currentPosition + '%)'; }); rightArrow.addEventListener('click', function() { currentPosition -= 100; // 向右移动一个图片的宽度 container.style.transform = 'translateX(-' + currentPosition + '%)'; }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值