导语:2018年8月,百度搜索资源平台发布的《百度移动搜索体验白皮书4.0》中提到图片页资源标准:"详情页中主体内容包括图片的情况下,图片应能点击调起大图、缩小放大功能使用自如,手势支持顺滑,图集能自由切换。"对于这一标准,有哪些案例可以参考呢?对于基础的点击调起大图功能,应该如何实现呢?《百度移动搜索落地页体验白皮书4.0专题解读》之《图片交互如何做会更好?》,将为你解答这些疑问。
优质的资源通畅是图文并茂的,优质图片所带来的直观体验,可以让用户快速获取信息,是中非常重要的一环。
但是,受限于移动端屏幕大小,考虑到用户流量等问题,详情页中主体内容的图片通常被默认设置为小图。而用户在浏览时,看到感兴趣的图片,往往希望能够在点击图片后获取大图,以便获取更详细的信息。
如下图所示,用户往往希望能够在点击图片后获取大图,并对图片进行局部放大和移动,以便查看图中的详细数据。

而对于图集来说,还需要有自由切换功能,才能够满足用户需求。
因此,详情页中主体内容包括图片的情况下,图片应能点击调起大图、缩小放大功能使用自如,手势支持顺滑,图集能自由切换。
如下图所示,详情页主体内容中的图片,点击后可以调起大图,缩小放大功能使用自如,手势支持顺滑,可以作为参考。

如下图所示,详情页主体内容中的图集,点击后可以调起大图,缩小放大功能使用自如,手势支持顺滑,且能够自由切换,可以作为参考。

普通的Web页面是无法直接查看图片的,而放大查看图片不仅仅是简单的放大图片,如果想要实现与原生手机应用中类似的放大查看图片的能力,需要通过 *** 代码进行一些动效和交互效果封装。
在MIP中,已经将图片查看效果封装到了<mip-img>组件内部,通过添加popup属性来直接使用,例如:<mip-img popup>。
使用popup以后效果如下:

对于MIP站来说,直接添加popup属性就可以实现点击调起大图的效果。而对于普通站点来说,也可以参考MIP的popup技术原理,升级自己的站点。
popup效果不算特别复杂,接下来通过如下示例为大家讲解popup在MIP中是如何实现的。
实现图片的popup效果,主要考虑以下几个功能:
- 图片popup(图片弹起):当前图片遵循约定动画曲线放大至更大,同时将背景变黑;
- 图片拖拽:图片进入放大查看状态以后,可以被拖拽,向下拖拽时可以退出放大浏览效果;
- 图片popdown(图片落坑):当图片从放大浏览状态退出时,应当遵循通过平滑动画回到原来图片位置的交互效果,简称落坑。
通过以上功能拆解,我们可以一起看一下几个图片popup的核心功能的代码实现:
① popup需要创建专用的弹层dom,代码示例如下:
// 创建弹层 dom function createPopup(element, img) { var mipPopWrap = document.querySelector('.mip-img-popUp-wrapper'); if (!!mipPopWrap && mipPopWrap.getAttribute('data-name') === 'mip-img-popUp-name' && mipPopWrap.parentNode.tagName.toLowerCase() === 'body') { mipPopWrap.querySelector('img').setAttribute('src', img.src); return mipPopWrap; } var popup = document.createElement('div'); // 阻止纵向滑动 new Gesture(popup, { preventY: true }); popup.className = 'mip-img-popUp-wrapper'; popup.setAttribute('data-name', 'mip-img-popUp-name'); // 创建图片预览图层 var popUpBg = document.createElement('div'); var innerImg = new Image(); popUpBg.className = 'mip-img-popUp-bg'; innerImg.className = 'mip-img-popUp-innerimg'; innerImg.src = img.src; popup.appendChild(popUpBg); popup.appendChild(innerImg); document.body.appendChild(popup); return popup; }
② 实现用户点击时的图片放大和背景变化效果,代码示例如下:
function bindPopup(element, img) { var popup; var popupBg; var popupImg; // 图片点击时展现图片 img.addEventlistener('click', function (event) { event.stopPropagation(); // 图片未加载则不弹层 if (img.width + img.naturalWidth === 0) { return; } popup = createPopup(element, img); popupBg = popup.querySelector('.mip-img-popUp-bg'); popupImg = popup.querySelector('img'); //触发图片落坑 popup.addEventListener('click', imagePop, false); var imgOffset = getImgOffset(img); var onResize = function () { imgOffset = getImgOffset(img); css(popupImg, imgOffset); naboo.animate(popupImg, getPopupImgPos(imgOffset.width, imgOffset.height)).start(); }; window.addEventListener('resize', onResize); css(popupImg, imgOffset); css(popupBg, 'opacity', 1); css(popup, 'dlay', 'block'); naboo.animate(popupImg, getPopupImgPos(imgOffset.width, imgOffset.height)).start(); css(img, 'visibility', 'hidden'); css(img.parentNode, 'zIndex', 'inherit'); }, false); }
③ 实现图片落坑,具体代码示例如下:
function imagePop() { naboo.animate(popupBg, { opacity: 0 }).start(); naboo.animate(popupImg, getImgOffset(img)).start(function () { css(img, 'visibility', 'visible'); css(popup, 'display', 'none'); }); popup.removeEventListener('click', imagePop, false);}
基于以上,我们基本可以实现图片的popup效果了。
提高用户体验,就要从用户的角度出发,满足用户的合理需求。期待我们从多角度,全方位共同提高用户体验。
注:若对本文有疑问,可以发送,我们将挑选出有代表性的问题予以解答。
许多企业在做网上排名时难以决议是做优化好仍是应该挑选网络竞价。今日,小编就来给我们说说这二者之间的优缺点,看看终究哪个更适合大多数人挑选。 一、竞价排名 利益: 1、见效快。付费后马上就能出现在关键词主页,排名靠出价凹凸自在操控,可控性强。 2、规模广。不约束关键词数...
网站页面的优化包括的是词频以及密度的优化,这两个方面尽管看似相同不过优化不同的,从词语出现的频率以及正文内容的词密度都是的要害点;想要获取有用的排名,这两点需求合理散布。 一、页面优化中什么是词频: 开始查找引擎算法的判定是,要害词出现的次数越多,也就是词频越高,那么页面的这个要害词...
跟着智能手机的遍及,Wap手机网站也逐步多了起来,移动查找优化也成了网站的新战场,移动端的优化跟着移动智能终端的遍及而显得尤为重要,乃至许多手机企业网站的建造也显得刻不容缓,所谓抢得先机即为赢得商机。 作为中文手机查找引擎百度移动查找,每天用户运用百度移动查找主张的查找恳求高达数亿次,所...
关于企业来说,建造高质站点的优势不只仅在于得到杰出的网站排名,相同也是打造公司品牌宣扬,以此获取相关的营销利益。那关于一个初期的新站来说,从网站建造开端就需求留意到多方面的内容,那咱们如何将新站打造成高质站点?所需求用到的技巧又有哪些?接下来我们一起看看吧。 一、网站翻开速度...
懂知识,就一定会做好的?在很多参与培训的来说,无论是基础、理论、概念在不同的培训机构中,所讲解的方式和理解程度都不一样,都说具备一定的排名规律,只要能先进于同行,你就具备竞争优势!SEO你懂,但懂和行是两码事。 对来说,经常会出现的问题,但是又不愿意或者没办法进行解决,到底有哪...
关于初学者而言,常常简略混杂与外部链接,咱们并不清楚二者之间的差异,这关于而言,却有着彻底不同的概念,比方:添加反链与添加外链,严厉意义上讲,这是两码事。 那么,反向链接与外链的差异有哪些? 简略举例,比方:X与Y这两个页面,假如SEO人员在Y的页面上,使用超链接指向了X...