Categories


Tags


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

导语: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,代码示例如下:

// 创建弹层 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, 'display', '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效果了。

四、结语

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

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

来源:百度搜索资源平台 百度搜索学堂


Public @ 2021-12-07 16:19:39

百度APP移动搜索落地页体验白皮书5.0-服务规范

4.4 服务规范服务闭环是指以用户需求为中心,能提供用户完整、全流程的服务体验。作为综合性的内容消费及服务平台,百度APP希望用户在搜索时不仅能满足用户的信息及资源获取需求,更能享受完整的服务流程,带给用户沉浸式的体验感受。4.4.1登录便捷登录需求作为用户享有各种服务需求的前提,必须做到登录简单便捷。4.4.1.1 站点及小程序的登录入口清晰明显,登录方式便捷,支持授权登录,比如百度账号授权等。

Public @ 2022-12-05 16:19:32

专题解读百度APP移动搜索落地页体验白皮书5.0

过去一年,在百度和全网开发者的共同努力下,搜索用户的浏览交互体验有了明显提升。为持续提升搜索用户体验,百度搜索产品技术团队经过用户调研、竞品分析、小流量测试等手段,对落地页体验标准进行了全新升级,正式推出《百度APP移动搜索落地页体验白皮书5.0》,期望继续与各位内容、服务提供者一同打造沉浸式的搜索体验,为亿万用户提供更优质便捷的搜索服务。查看全文浏览页面流畅页面打开速度快,整体布局合理、排版精良

Public @ 2020-02-22 16:18:55

百度搜索大讲堂:移动新搜索下新规则,网站应如何应对?

2017年8月3日,百度搜索VIP大讲堂成功在北京举办,包括中国网、光明网、腾讯网、搜狐网、大众点评、58同城、美团等150余个网站的技术负责人参与了此次会议。百度搜索VIP大讲堂作为业内知名的培训会议一直广受关注,百度搜索希望通过此类活动向互联网生态内的所有站点普及搜索优化知识,给中国网民提供优质的浏览体验。移动互联网发展至今日,各项技术日趋成熟,百度移动搜索也在不断进化,在今天的大讲堂上,百度

Public @ 2013-04-21 16:20:07

官方解读:如何提高落地页体验?

一、落地页体验白皮书总览百度搜索一直致力于提升搜索用户的浏览体验,营造健康的搜索生态。近几年百度搜索持续发布《百度移动搜索落地页体验白皮书》,全力以赴改进和迭代搜索策略,坚决与低劣广告作战,与各位开发者共创健康优质的搜索服务。《百度APP移动搜索落地页体验白皮书5.0》目前是搜索资源平台最新最全的官方指导文档,从信息获取、页面浏览、交互操作、服务规范四方面制订了更加明确、细致的规范要求,全方位提升

Public @ 2013-08-14 16:18:57

更多您感兴趣的搜索