Hi,are you ready?

准备好开始了吗?
那就与我们取得联系吧

有一个网站项目想和我们谈谈吗?您可以填写右边的表格,让我们了解您的项目需求,这是一个良好的开始,我们将会尽快与你取得联系。当然也欢迎您 给我们写信或是打电话,让我们听到你的声音!

Distance远近互联网络运营服务商

地 址:河北省石家庄市新华区华强广场7楼

电 话:14730427447

E-mail:815752879@qq.com

填写您的项目信息

图片交互如何做会更好? | 白皮书 4.0 专题解读

发布时间:2018-11-23T11:03:24

白皮书 4.0 专题解读

为了提升移动搜索落地页体验,营造优质的移动搜索生态环境,百度搜索将在 11 月下旬对冰桶算法进行升级,上线冰桶算法 5.0 。为了强调用户移动搜索落地页体验的重要性,特将白皮书4.0专题解读进行整理,再次向大家推送(建议关注百度搜索资源平台官方微信公众号,回复“白皮书4.0专题解读”收藏所有解读文章)。

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

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

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

白皮书 4.0 专题解读

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

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

01

参考案例

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

1542942520(1).jpg

02

参考案例

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

白皮书 4.0 专题解读

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

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

01

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

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

使用popup以后效果如下:

白皮书 4.0 专题解读

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

02

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效果了。

结语

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

【相关推荐】
返回列表
在线沟通

Are you interested in ?

  您感兴趣吗?

有关我们服务的更多信息,请联系

147 3042 7447 周经理

与我们合作

与远近互联合作,您将会得到更成熟的网络品牌建设服务。我们以客户至上,同时也相互挑战,力求呈现更好的网络品牌建设成果。

项目经理热线(周经理):

147 3042 7447

TOP

QQ客服

14730427447