logo
  • 搜索学堂
  • 搜索服务
  • 互动交流
  • 资源合作
  • 用户中心
登录
推荐内容 智能小程序 工具解读 搜索规范 合作共建 基础开发 创作者小课堂

资源提交

小程序资源
  • 资源提交及校验
站点资源
  • 快速收录
  • 普通收录
  • 移动适配
  • 死链提交

数据统计

小程序资源
  • 流量统计
站点资源
  • 索引量
  • 流量与关键词
  • 抓取频次
  • 抓取诊断
  • 抓取异常
  • Robots

搜索展现

  • HTTPS认证
  • 站点子链
  • 站点属性
  • 专业问答
  • 专业问答托管页
  • 落地页视频转存
  • 视频极速服务
  • 医疗权威资源
  • 热议资源

站点优化与维护

  • 网站改版
论坛 反馈中心 搜索用户建议 VIP俱乐部
合作专题 申请历史
站点管理 消息提醒 联系方式 管理员设置 分润中心
  • 在线咨询

  • 反馈中心

  • 回到顶部

搜索学堂 【白皮书4.0解读】图片交互如何做会更好?

【白皮书4.0解读】图片交互如何做会更好?

发布日期:2018-10-25

导语:2018年8月,百度搜索资源平台发布的《百度移动搜索落地页体验白皮书4.0》中提到图片页资源标准:“详情页中主体内容包括图片的情况下,图片应能点击调起大图、缩小放大功能使用自如,手势支持顺滑,图集能自由切换。”对于这一标准,有哪些案例可以参考呢?对于基础的点击调起大图功能,应该如何实现呢?《百度移动搜索落地页体验白皮书4.0专题解读》之《图片交互如何做会更好?》,将为你解答这些疑问。

一、为什么图片要增加交互功能?


优质的资源通畅是图文并茂的,优质图片所带来的直观体验,可以让用户快速获取信息,是用户体验中非常重要的一环。


但是,受限于移动端屏幕大小,考虑到用户流量等问题,详情页中主体内容的图片通常被默认设置为小图。而用户在浏览时,看到感兴趣的图片,往往希望能够在点击图片后获取大图,以便获取更详细的信息。


如下图所示,用户往往希望能够在点击图片后获取大图,并对图片进行局部放大和移动,以便查看图中的详细数据。




而对于图集来说,还需要有自由切换功能,才能够满足用户需求。


因此,详情页中主体内容包括图片的情况下,图片应能点击调起大图、缩小放大功能使用自如,手势支持顺滑,图集能自由切换。


二、参考案例


参考案例1


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



参考案例2


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




三、以点击调起大图为例谈技术实现


普通的Web页面是无法直接查看图片的,而放大查看图片不仅仅是简单的放大图片,如果想要实现与原生手机应用中类似的放大查看图片的能力,需要通过JS代码进行一些动效和交互效果封装。


1. MIP站添加popup属性即可直接使用


在MIP中,已经将图片查看效果封装到了<mip-img>组件内部,通过添加popup属性来直接使用,例如:<mip-img popup>。


使用popup以后效果如下:




对于MIP站来说,直接添加popup属性就可以实现点击调起大图的效果。而对于普通站点来说,也可以参考MIP的popup技术原理,升级自己的站点。


2. popup技术原理详解

popup效果不算特别复杂,接下来通过如下示例为大家讲解popup在MIP中是如何实现的。


(1)功能拆解


实现图片的popup效果,主要考虑以下几个功能: 

- 图片popup(图片弹起):当前图片遵循约定动画曲线放大至最大,同时将背景变黑; 

- 图片拖拽:图片进入放大查看状态以后,可以被拖拽,向下拖拽时可以退出放大浏览效果; 

- 图片popdown(图片落坑):当图片从放大浏览状态退出时,应当遵循通过平滑动画回到原来图片位置的交互效果,简称落坑。


(2) 代码实现


通过以上功能拆解,我们可以一起看一下几个图片popup的核心功能的代码实现:


(3)popup实现


① popup需要创建专用的弹层dom,代码示例如下:

  1. // 创建弹层 dom
  2. function createPopup(element, img) {
  3. var mipPopWrap = document.querySelector('.mip-img-popUp-wrapper');
  4. if (!!mipPopWrap && mipPopWrap.getAttribute('data-name') === 'mip-img-popUp-name'
  5. && mipPopWrap.parentNode.tagName.toLowerCase() === 'body') {
  6. mipPopWrap.querySelector('img').setAttribute('src', img.src);
  7. return mipPopWrap;
  8. }
  9. var popup = document.createElement('div');
  10. // 阻止纵向滑动
  11. new Gesture(popup, {
  12. preventY: true
  13. });
  14. popup.className = 'mip-img-popUp-wrapper';
  15. popup.setAttribute('data-name', 'mip-img-popUp-name');
  16. // 创建图片预览图层
  17. var popUpBg = document.createElement('div');
  18. var innerImg = new Image();
  19. popUpBg.className = 'mip-img-popUp-bg';
  20. innerImg.className = 'mip-img-popUp-innerimg';
  21. innerImg.src = img.src;
  22. popup.appendChild(popUpBg);
  23. popup.appendChild(innerImg);
  24. document.body.appendChild(popup);
  25. return popup;
  26. }


② 实现用户点击时的图片放大和背景变化效果,代码示例如下:

  1. function bindPopup(element, img) {
  2. var popup;
  3. var popupBg;
  4. var popupImg;
  5. // 图片点击时展现图片
  6. img.addEventListener('click', function (event) {
  7. event.stopPropagation();
  8. // 图片未加载则不弹层
  9. if (img.width + img.naturalWidth === 0) {
  10. return;
  11. }
  12. popup = createPopup(element, img);
  13. popupBg = popup.querySelector('.mip-img-popUp-bg');
  14. popupImg = popup.querySelector('img');
  15. //触发图片落坑
  16. popup.addEventListener('click', imagePop, false);
  17. var imgOffset = getImgOffset(img);
  18. var onResize = function () {
  19. imgOffset = getImgOffset(img);
  20. css(popupImg, imgOffset);
  21. naboo.animate(popupImg, getPopupImgPos(imgOffset.width, imgOffset.height)).start();
  22. };
  23. window.addEventListener('resize', onResize);
  24. css(popupImg, imgOffset);
  25. css(popupBg, 'opacity', 1);
  26. css(popup, 'display', 'block');
  27. naboo.animate(popupImg, getPopupImgPos(imgOffset.width, imgOffset.height)).start();
  28. css(img, 'visibility', 'hidden');
  29. css(img.parentNode, 'zIndex', 'inherit');
  30. }, false);
  31. }


③ 实现图片落坑,具体代码示例如下:

  1. function imagePop() {
  2. naboo.animate(popupBg, {
  3. opacity: 0
  4. }).start();
  5. naboo.animate(popupImg, getImgOffset(img)).start(function () {
  6. css(img, 'visibility', 'visible');
  7. css(popup, 'display', 'none');
  8. });
  9. popup.removeEventListener('click', imagePop, false);
  10. }

基于以上,我们基本可以实现图片的popup效果了。

四、结语


提高用户体验,就要从用户的角度出发,满足用户的合理需求。期待我们从多角度,全方位共同提高用户体验。


注:若对本文有疑问,可以发送邮件,我们将挑选出有代表性的问题予以解答。

推荐阅读

  • 星座命理行业搜索体验规范
  • 百度移动APP落地页体验白皮书解读
  • 落地页体验白皮书解读
  • 白皮书5.0解读—落地页中如何设置...
  • 白皮书5.0解读—什么样的顶部嵌入...
  • 白皮书5.0解读—内容模块之间为何...
  • 白皮书5.0解读—如何合理设置展开...
智能小程序 投诉平台 百度统计 百度智能云 百度云加速 百度安全 百度大脑 百度保障 百度开发者中心 联系我们 微信公众号
©2022 Baidu 使用百度前必读 京ICP证030173号