当前位置:首页 > SEO推广 > 正文内容

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

a811625532年前 (2024-07-09)SEO推广18

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

四、结语

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

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

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://www.2345hao.cn/blog/index.php/post/18884.html

分享给朋友:

“百度SEO:图片交互如何做会更好?” 的相关文章

如何打造高质新站点?新站SEO优化技巧

如何打造高质新站点?新站SEO优化技巧

关于企业来说,建造高质站点的优势不只仅在于得到杰出的网站排名,相同也是打造公司品牌宣扬,以此获取相关的营销利益。那关于一个初期的新站来说,从网站建造开端就需求留意到多方面的内容,那咱们如何将新站打造成高质站点?所需求用到的技巧又有哪些?接下来我们一起看看吧。 一、网站翻开速度...

SEO反向链接与外链区别,如何查询反向链接?

SEO反向链接与外链区别,如何查询反向链接?

关于初学者而言,常常简略混杂与外部链接,咱们并不清楚二者之间的差异,这关于而言,却有着彻底不同的概念,比方:添加反链与添加外链,严厉意义上讲,这是两码事。 那么,反向链接与外链的差异有哪些? 简略举例,比方:X与Y这两个页面,假如SEO人员在Y的页面上,使用超链接指向了X...

做SEO优化需要注意这十大问题

做SEO优化需要注意这十大问题

很多站长子啊做优化的过程中,一味为了排名权重而忽略细节问题,导致优化进度缓慢或者优化进入死循环,今天小编来给大家梳理关于优化注意的十大问题。一起来看看吧。 一、网站标题的写法   很多朋友都让我分析一下他们网站的标题,大部分的网站标题都或多或少的有问题,网站标题...

有利于网站的URL优化方法是什么?

有利于网站的URL优化方法是什么?

其实我们在做的过程中,有许多的地方值得注意,譬如网站,网站、网站URL抒写格式等,做好网站优化的前提是尽可能处理好网站优化细节。今天小编就和大家分享有利于网站的URL优化方法,一起来看看吧。 一、域名的选择   域名应该更为合理,让域名更容易让用户记住,更符合你...

解析网站主动推送百度后不收录的影响因素?

解析网站主动推送百度后不收录的影响因素?

网站不收录就不会有排名,因百度算法的不断更新,百度对于网站的收录率也越来越低,是什么原因导致文章不被的呢?百度针对不收录情况,推出了开放百度链接主动推送的接口,很多站长也都是通过这个百度接口将不收录网站通过接口自动推送给百度搜索引擎,但是在使用这个推送接口的时候,大家肯定也发现了不少问题,比如...

摸清搜索引擎吸收外链胃口,适当的外链积累可增添优化进程

摸清搜索引擎吸收外链胃口,适当的外链积累可增添优化进程

在途中,主要分为站内优化和站外优化,其中站内优化有网站结构、内容优化,网站,网站网址优化等等,站外优化有分为交换,博客外链培养,论坛发帖外链,站内优化和站外优化在网站优化都占有一定地位,两者都不可缺少,今天主要讨论下站外优化。站外优化简单的说就是到别人的网站留下自己的网站网址,让搜索引擎蜘蛛在...