百度SEO:图片交互如何做会更好?

05-23 05:30 好宝宝网站收录 1

导语: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, 'd      ISP    lay', '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效果了。

四、结语

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

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

免责声明

任何关于疾病的建议都不能替代执业医师的面对面诊断,请谨慎参阅。本站不承担由此引起的法律责任。

本站上所有内容均出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。

热门网站
  • 百度网盘
    百度网盘为您提供文件的网络备份、同步和分享服务。空间大、速度快、安全稳固,支持教育网加速,支持手机端。注册使用百度网盘即可享受免费存储空间。
  • 网易体育
    体育,体育频道,包含体育新闻,NBA,CBA,英超,意甲,西甲,冠军杯,体育比分,足彩,福彩,体育秀色,网球,F1,棋牌,乒羽,体育论坛,中超,中国足球,综合体育等专业体育门户网站
  • 中国财经网
    以“中国财经”、“中国财经APP”、中国财经双微等为核心业务平台,实现多屏互动,重点关注宏观经济、金融、证券、上市公司、房产、科技等领域,为用户提供时效、专业、全面的财经信息及综合类服务。
  • 简书
    简书是一个优质的创作社区,在这里,你可以任性地创作,一篇短文、一张照片、一首诗、一幅画……我们相信,每个人都是生活中的艺术家,有着无穷的创造力。
  • 武汉大学
    武汉大学(Wuhan University),简称武大(WHU),位于湖北省武汉市,是教育部直属的综合性全国重点大学, 中央直管高校,国家首批“双一流”、“985工程”、“211工程”重点建设高校。入选“101计划”、英才计划、国家建设高水平大学公派研究生项目,为医学“双一流”建设联盟、欧亚-太平洋大学联盟、中英高等教育人文联盟成员,长江中游城市群“双一流”高校联盟理事长单位。 武汉大学溯源于1893年清末湖广总督张之洞奏请清政府创办的自强学堂,历经传承演变,1928年定名为国立武汉大学,是近代中国第一批国立大学。 1960年被确定为全国重点综合性大学,1995年被确定为国家“211工程”重点建设高校。2000年武汉大学与武汉水利电力大学、武汉测绘科技大学、湖北医科大学合并组建新的武汉大学,2001年进入国家“985工程”重点建设高校行列,2017年入选国家“双一流”建设高校。
  • 301解放军总医院
    中国人民解放军总医院(301医院)创建于1953年,是集医疗、保健、教学、科研于一体的大型现代化综合性医院,直属于中国人民解放军联勤保障部队。医院是中央重要保健基地,承担军委、总部等多个体系单位、官兵的医疗保健和各军区、军兵种转诊、后送的疑难病诊治任务。医院同时又是解放军医学院,以研究生教育为主,是全军唯一一所医院办学单位。
  • 厚大法考
    厚大法考隶属于北京厚大轩成教育科技股份公司,是一家集司法考试培训、法硕培训、律所、律师培训等相关法律培训服务的机构。厚大法考从成立之初凭借免费模式,各友商效仿引入免费模式,让法考行业实现对学员的教育资源共享 。2016年,厚大股份挂牌上市。2017年,随着多位名师的加入,以及厚大各职能部门的协作,厚大组成了行业学院派名师阵容。厚大罗翔老师在2020年出圈,掀起了全民法律热。截止到2023年,厚大法考图书发行量已经突破一千万册,免费课件播放量达一亿次 。
手机号码吉凶查询网