使用JavaScript解决网页图片拉伸问题

转载请注明出处:http://blog.csdn.net/xiaojimanman/article/details/53084716

http://www.llwjy.com/blogdetail/92b85d1cdb0343a7bd6d8dd0868c0f82.html

个人博客站已经上线了,网址 www.llwjy.com ~欢迎各位吐槽~

-------------------------------------------------------------------------------------------------

      在开始之前先打一个小小的广告,自己创建一个QQ群:321903218,点击链接加入群【Lucene案例开发】,主要用于交流如何使用Lucene来创建站内搜索后台,同时还会不定期的在群内开相关的公开课,感兴趣的童鞋可以加入交流。


问题描述

      这段时间在做PM的需求的时候突然发现一个问题,产品上的图片来自多个第三方,具体的尺寸无法确定,如果直接在样式中写死图片的尺寸大小就会出现图片拉伸的现象,十分影响产品的美观,因此希望可以找到一个比较好的解决方案。自己先做了一个简单的demo来展示问题。

<html>
<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
	<script src="./js/jquery-1.11.1.min.js"></script>
	<style>
		.img1{width:200px;height:200px;border: 1px solid #000;overflow: hidden;margin: 10px;}
		.img2{width:200px;height:90px;border: 1px solid #000;overflow: hidden;margin: 10px;}	
	</style>
</head>	
<body>
	<div class="img1" style="width:">
		<img id="img1" src="./img/1.jpg" height="100%" width="100%">
	</div>
	<div class="img2" style="width:">
		<img id="img2" src="./img/1.jpg" height="100%" width="100%">
	</div>
</body>
</html>



      上述这种情况还是挺影响美观的,是否可以考虑动态的设置图片的尺寸呢?


解决思路

      是否可以在浏览器加载图片资源后,获取图片的真实尺寸和图片容器的大小,然后动态地设置图片的width、height属性。


获取图片的真实尺寸

      html5下已经提供了相应的方法来返回图片的真实尺寸大小(img.natural

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
你可以使用JavaScript和CSS来实现网页图片的轮转切换: 1. 首先,你需要在HTML中创建一个包含图片的容器,例如div元素。 2. 在CSS中,你需要设置容器的宽度和高度,并将其中的图片设置为绝对定位,以便它们可以在容器中移动。 3. 接下来,你可以创建一个JavaScript函数来实现轮转切换。该函数应该接受一个参数,即要显示的下一张图片的索引。在函数内部,你可以使用CSS的transform属性来移动当前显示的图片,并将下一张图片移动到可见区域。 4. 最后,你可以使用setInterval函数来定期调用该函数,以便自动轮转图片。 下面是一个简单的示例代码,可以帮助你入门: HTML: ```html <div id="image-container"> <img src="image1.jpg" class="active"> <img src="image2.jpg"> <img src="image3.jpg"> </div> ``` CSS: ```css #image-container { position: relative; width: 500px; height: 300px; } #image-container img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 1s ease-in-out; } #image-container img.active { opacity: 1; } ``` JavaScript: ```javascript var currentIndex = 0; var images = document.querySelectorAll('#image-container img'); var intervalId = setInterval(changeImage, 3000); function changeImage() { currentIndex = (currentIndex + 1) % images.length; images[currentIndex].classList.add('active'); images[currentIndex - 1].classList.remove('active'); } ``` 在这个示例中,我们首先定义了一个变量currentIndex来跟踪当前显示的图片的索引。然后,我们使用document.querySelectorAll函数选择所有的图片元素,并将它们存储在一个名为images的数组中。接下来,我们使用setInterval函数每3秒钟调用一次changeImage函数。该函数使用currentIndex变量来确定要显示的下一张图片的索引,并使用classList.add和classList.remove方法来添加和删除“active”类,以便将当前显示的图片和下一张图片的透明度进行切换。 请注意,这只是一个简单的示例,可以根据你的需求进行修改和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值