基于JavaScript实现移动端点击图片查看大图点击大图隐藏

今天找到了一个我用了很好的方法,点击缩略图,放大居中展示,且参数可调,亲测可靠。

代码使用意见,将下面的代码放到本地测试效果,可以用一张自己的照片,点击会放大,再次点击还原。

 

一、需求 

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

二、代码

<title>JQuery点击图片查看大图by starof</title>

<style type="text/css">

.exampleImg { height:100px; cursor:pointer;}

</style>

<script src="http://code.jquery.com/jquery-latest.js"></script>

<script type="text/javascript">

//alert($);

// (function (window, undefined) {

// var MyJQuery = function () {

// window.MyjQuery = window.$ = jQuery; window.$ = MyJQuery;

// };

// })(window);

// alert($);

$.fn.ImgZoomIn = function () {

bgstr = '<div id="ImgZoomInBG" style=" background:#000000; filter:Alpha(Opacity=70); opacity:0.7; position:fixed; left:0; top:0; z-index:10000; width:100%; height:100%; display:none;"><iframe src="about:blank" frameborder="5px" scrolling="yes" style="width:100%; height:100%;"></iframe></div>';

//alert($(this).attr('src'));

imgstr = '<img id="ImgZoomInImage" src="' + $(this).attr('src')+'" onclick=$(\'#ImgZoomInImage\').hide();$(\'#ImgZoomInBG\').hide(); style="cursor:pointer; display:none; position:absolute; z-index:10001;" />';

if ($('#ImgZoomInBG').length < 1) {

$('body').append(bgstr);

}

if ($('#ImgZoomInImage').length < 1) {

$('body').append(imgstr);

}

else {

$('#ImgZoomInImage').attr('src', $(this).attr('src'));

}

//alert($(window).scrollLeft());

//alert( $(window).scrollTop());

$('#ImgZoomInImage').css('left', $(window).scrollLeft() + ($(window).width() - $('#ImgZoomInImage').width()) / 2);

$('#ImgZoomInImage').css('top', $(window).scrollTop() + ($(window).height() - $('#ImgZoomInImage').height()) / 2);

$('#ImgZoomInBG').show();

$('#ImgZoomInImage').show();

};

$(document).ready(function () {

$("#imgTest").bind("click", function () {

$(this).ImgZoomIn();

});

});

</script>

 

 

<div>

<!--第一种写法-->

<img class="exampleImg" id="imgTest" src="images/03.jpg">

<!--第二种写法-->

<img class="exampleImg" onclick="$(this).ImgZoomIn();" src="images/p1_nav2.png">

</div>

三、技巧

 

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

<dl>

 <dd style="display: block;">

  <img onclick="$(this).ImgZoomIn();" src="images/four-duche.jpg">

  <a class="topleft" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/11.jpg"></a>

  <a class="topright" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/12.jpg"></a>

  <a class="bottomleft" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/13.jpg"></a>

  <a class="bottomright" onclick="$(this).ImgZoomIn();" href="javascript:;" src="images/14.jpg"></a>

 </dd>

 ...

</dl>

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');

    });

  }

};

全文参考:http://www.php.cn/js-tutorial-4421.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue3中实现移动端图片双指控制放大缩小和拖动,可以利用Vue官方提供的指令v-touch,结合自定义指令和事件处理进行实现。 首先,在需要实现双指控制的图片元素上,使用v-touch指令绑定一个Touch事件。 ```html <template> <div> <img src="imageSrc" v-touch="handleTouch"> </div> </template> ``` 然后,在Vue的setup函数中,定义handleTouch方法来处理触摸事件。可以通过event.touches获取触摸点信息,并根据触摸点的个数来判断是拖动还是放大缩小操作。 ```javascript <script> import { ref } from 'vue'; export default { setup() { const imageSrc = ref('path/to/image'); const handleTouch = (event) => { const touches = event.touches; if (touches.length === 2) { // 双指操作:放大缩小 // 获取两个触摸点的距离 const distance = Math.hypot(touches[0].clientX - touches[1].clientX, touches[0].clientY - touches[1].clientY); // 根据距离放大或缩小图片 zoomImage(distance); } else if (touches.length === 1) { // 单指操作:拖动 // 记录当前触摸点的坐标 const touch = touches[0]; const startX = touch.clientX; const startY = touch.clientY; // 监听触摸点的移动 document.addEventListener('touchmove', handleMove); // 监听触摸点的离开 document.addEventListener('touchend', handleEnd); // 处理移动事件 function handleMove(event) { event.preventDefault(); // 计算偏移量 const offsetX = event.touches[0].clientX - startX; const offsetY = event.touches[0].clientY - startY; // 根据偏移量拖动图片 dragImage(offsetX, offsetY); } // 处理离开事件 function handleEnd() { // 移除事件监听 document.removeEventListener('touchmove', handleMove); document.removeEventListener('touchend', handleEnd); } } }; // 放大缩小图片 const zoomImage = (distance) => { // 实现放大缩小操作 }; // 拖动图片 const dragImage = (offsetX, offsetY) => { // 实现拖动操作 }; return { imageSrc, handleTouch, zoomImage, dragImage }; } }; </script> ``` 在zoomImage和dragImage方法中,根据传入的参数来实现图片的放大缩小和拖动操作。具体实现方式可以根据项目需求选择。 需要注意的是,由于涉及到与DOM直接交互,所以在Vue3的Composition API中,需要使用document.addEventListener和document.removeEventListener来监听和移除事件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值