php图片点击查看大图,基于JavaScript实现移动端点击图片查看大图点击大图隐藏_javascript技巧...

一、需求

点击图片查看大图,再点大图隐藏。多用于移动端,因为移动端屏幕小,可能需要查看大图。

二、代码

JQuery点击图片查看大图by starof

03.jpg

p1_nav2.png

三、技巧

因为移动端无法添加热点,最终一个解决方法是使用四个a标签定位到左上角,右上角,左下角,右下角四个区域。

four-duche.jpg

...

css

.topleft,.topright,.bottomleft,.bottomright{

width:50%;

height:50%;

position:absolute;

}

.topleft{

/*background-color:red;*/

top:0;

left:0;

}

.topright{

/*background-color:green;*/

top:0;

right:0;

}

.bottomleft{

/*background-color:blue;*/

bottom:0;

left:0;

}

.bottomright{

/*background-color:yellow;*/

bottom:0;

right:0;

}

PS:手机网站移动端图片实现延迟加载

由于国内的电信网络性价比的限制,和手机处理能力的差异,在设计一个无线应用的时候,

为用户节省流量是一个非常重要的考虑因素。可以说每一个字节都应该为客户端节省。

节约流量可以从以下几个方面关注:

一、使用缓存 比如 利用浏览器本地存储 前面已经讨论过

二、延迟加载代码 (触底检测,通过接口获取数据)

三、资源的延迟加载,图片出现在可视区域再加载,(不考虑自动播放的情况下)音频视频按用户点击加载。

今天简单说一下图片延迟加载的实现方式。

例子基于jQuery 和 jQuery mobile

原理:用户滑动屏幕,屏幕滚动结束(用jQuery 提供的 window scrollstop 事件合适 ) 检测出现在viewport中的图片。

替换图片的 真正 src 属性即可。

技巧:滚动结束之后不要立即检测加载,设置一秒延时,也许用户会立即开始下一次滚屏,基于现在的网络环境,1秒的延时可以说明用户真正想查看这些内容。用微信的朋友可以仔细体验一下这一点。

由于有时钟的控制,当用户频繁快速翻动屏幕,不会发大量请求。

主要代码:

var refreshTimer = null,

mebook = mebook || {};

/*

*滚动结束 屏幕静止一秒后检测哪些图片出现在viewport中

*和PC端不同 由于无线速度限制 和手机运算能力的差异 1秒钟的延迟对手机端的用户来说可以忍受

*/

$(window).on('scrollstop', function () {

if (refreshTimer) {

clearTimeout(refreshTimer);

refreshTimer = null;

}

refreshTimer = setTimeout(refreshAll, 1e3);

});

$.belowthefold = function (element) {

var fold = $(window).height() + $(window).scrollTop();

return fold <= $(element).offset().top;

};

$.abovethetop = function (element) {

var top = $(window).scrollTop();

return top >= $(element).offset().top + $(element).height();

};

/*

*判断元素是否出现在viewport中 依赖于上两个扩展方法

*/

$.inViewport = function (element) {

return !$.belowthefold(element) && !$.abovethetop(element)

};

mebook.getInViewportList = function () {

var list = $('#bookList li'),

ret = [];

list.each(function (i) {

var li = list.eq(i);

if ($.inViewport(li)) {

mebook.loadImg(li);

}

});

};

mebook.loadImg = function (li) {

if (li.find('img[_src]').length) {

var img = li.find('img[_src]'),

src = img.attr('_src');

img.attr('src', src).load(function () {

img.removeAttr('_src');

});

}

};

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript实现点击图片放大可以通过以下步骤进行: 1. HTML 结构:在 HTML 中,你需要有一个包含图片的容器元素(例如 div)和一个用于显示放大图片的元素(例如 img 或 div)。给图片添加一个点击事件监听器,以便在点击时触发放大效果。 ```html <div id="imageContainer"> <img src="小图片.jpg" alt="图片" id="smallImage"> </div> <div id="zoomedImageContainer"> <img src="大图片.jpg" alt="放大图片" id="zoomedImage"> </div> ``` 2. CSS 样式:使用 CSS 来设置图片容器和放大图片的样式,并将放大图隐藏起来。 ```css #imageContainer { position: relative; } #zoomedImageContainer { position: absolute; top: 0; left: 0; display: none; } #zoomedImageContainer img { width: 100%; height: auto; } ``` 3. JavaScript 事件处理:使用 JavaScript 来处理点击事件,当点击图片时,显示放大图片,并根据鼠标位置进行定位。 ```javascript // 获取元素 const smallImage = document.getElementById("smallImage"); const zoomedImageContainer = document.getElementById("zoomedImageContainer"); // 添加点击事件监听器 smallImage.addEventListener("click", function() { // 显示放大图片 zoomedImageContainer.style.display = "block"; // 设置放大图片的位置 const smallImageRect = smallImage.getBoundingClientRect(); zoomedImageContainer.style.top = smallImageRect.top + "px"; zoomedImageContainer.style.left = smallImageRect.right + "px"; }); // 点击大图片外的区域,隐藏大图片 document.addEventListener("click", function(event) { if (!zoomedImageContainer.contains(event.target) && event.target !== smallImage) { zoomedImageContainer.style.display = "none"; } }); ``` 这样,当用户点击图片时,放大图片会显示在其旁边,再次点击大图片外的区域,放大图片会隐藏起来。你可以根据实际需求对样式和代码进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值