余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

使缩略图或项目的标题粘滞标题概念(标题的作用)

xiyangw 2022-12-05 10:40 26 浏览 0 评论

一个关于如何使缩略图或项目的标题“粘”,以保持在窗口或视口中可见的小技巧。

使缩略图或项目的标题粘滞标题概念(标题的作用)


在创建缩略图网格时,我们通常希望在悬停时显示图片标题以提供有关该项目的更多信息。图片标题通常显示在缩略图的非常特定的部分,无论是在顶部,中间还是在底部。将标题添加到缩略图的底部时,可能会出现溢出视口的缩略图(即,部分超出“折叠”的位置),但是标题不会被看到,因为它出现在缩略图的底部图像不可见。用户将不得不滚动该页面才能看到该项目的底部,并最终看到标题。

一个小窍门可以通过简单地使标题“粘性”来解决这个问题。这意味着不仅在每个缩略图的底部都可以看到标题,而且在任何地方都可以看到标题,如果缩略图悬停在当前视图的上方,它们会粘在页面的底部。

我们基本上所做的是模仿职位:粘性,但由于在许多浏览器中尚不支持,所以我们会做一些JavaScript来达到相同的结果。我们将使用jQuery。

主要思路是看一个悬浮元素何时溢出视口,并通过将其位置从绝对位置改变为固定位置来在正确的位置显示标题。

举个例子,让我们用一个简单的数字和图形的网格:

<div class="grid clearfix" id="grid">

<figure>

<img src="images/4.jpg">

<figcaption>

<a href="http://drbl.in/fWMT">Fall 7 Times Stand Up 8</a> by Erika Mackley

</figcaption>

</figure>

<figure><!-- ... --></figure>

<figure><!-- ... --></figure>

<figure><!-- ... --></figure>

<!-- ... -->

</div>

在我们的演示中,我们使用jQuery Masonry来创建一个整齐的网格。

我们来看看figcaption元素的结构样式(查看所有样式,看一下style.css)。标题应该是绝对的,我们将设置自动的左侧。这很重要,因为当我们切换到固定位置时,我们希望标题从其父容器的左侧开始。我们设置一个-60像素的底部值,以隐藏标题(减去它自己的高度)。请注意,父容器需要将其溢出设置为“隐藏”。

当我们将鼠标悬停在图上时,我们还添加了一个将底部动画为0的小转换:

.grid figure figcaption {

position: absolute;

left: auto;

width: 100%;

height: 60px;

bottom: -60px;

transition: bottom 0.2s ease-in-out;

}

.grid figure:hover figcaption {

bottom: 0px;

}

现在,我们要检查是否在底部切断了悬停的缩略图,即在窗口视图之外。如果是的话,我们将标题的位置改为固定,并设置一个宽度(否则只会愉快地展开直到页面结束)。

让我们开始创建一个名为bottomInViewport的自定义jQuery选择器,我们将帮助我们确定是否应该呈现图像的标题。

$.extend( $.expr[':'], {

bottomInViewport : function( el ) {

var scrollTop = ( document.documentElement.scrollTop || document.body.scrollTop ),

elOffsetTop = $( el ).offset().top,

elH = $( el ).height(),

descrH = $( el ).find( 'figcaption' ).outerHeight(true),

winH = ( window.innerHeight && window.innerHeight < $( window ).height() ) ? window.innerHeight : $( window ).height();

return ( elOffsetTop + elH > scrollTop && elOffsetTop + elH < scrollTop + winH ) || ( scrollTop + winH - elOffsetTop < descrH );

}

});

如果元素完全位于视口内,则该函数返回true,这意味着底部没有被切断。如果元素不在视口中,但是可见部分太小而不符合标题,它也会返回true。在这些情况下,我们的脚本不应该做任何事情,标题将像往常一样简单地显示。如果函数返回false,我们将通过将其位置设置为固定来显示标题。由于我们在CSS中将底部定义为0,因此它将显示在页面的底部,就在我们需要的地方。我们还必须将宽度设置为其父宽度(图):

function changeToFixed( $description, itemWidth ) {

$description.css({ position: 'fixed', width: itemWidth });

}

function resetStyle( $description, delay ) {

setTimeout( function() { $description.css({ position: 'absolute', width: '100%'}); }, delay || 0 );

}

我们将需要绑定mouseenter和mouseleave事件的项目,也滚动事件到窗口,而悬停在一个项目上:

$items.on( 'mouseenter mouseleave', function( event ) {

var $item = $( this ), itemWidth = $item.width(),

$description = $item.find( 'figcaption' );

switch( event.type ) {

case 'mouseenter' :

if( !$item.is( ':bottomInViewport' ) ) {

$item.data( 'sticky', true );

changeToFixed( $description, itemWidth );

}

$( window ).on( 'scroll', function () {

var inviewport = $item.is( ':bottomInViewport' );

if( !inviewport && !$item.data( 'sticky' ) ) {

$item.data( 'sticky', true );

changeToFixed( $description, itemWidth );

}

else if( inviewport && $item.data( 'sticky' ) ) {

$item.data( 'sticky', false );

resetStyle( $description );

}

} );

break;

case 'mouseleave' :

if( $item.data( 'sticky' ) ) {

$item.data( 'sticky', false );

resetStyle( $( this ).find( 'figcaption' ), 200 );

}

$( window ).off( 'scroll' );

break;

}

} );

当我们盘旋在一个项目上时,我们检查是否应该使用我们的技巧。此外,我们将滚动事件绑定到窗口,在那里我们将检查是否应该应用或重置我们滚动的技巧。当我们离开该项目时,我们从窗口中解除滚动事件,并重置项目的样式(如果先前已应用了该技巧)。

而就是这样!看看演示,并将鼠标悬停在底部的一个项目上,以查看效果。然后滚动。您将看到字幕在底部如何粘到“自然”位置。

我希望你喜欢这个小窍门,并发现它有用!

相关推荐

spring利用spring.handlers解析自定义配置(spring validation 自定义)

一、问题我们在spring的xml配置文件里经常定义各种各样的配置(tx、bean、mvc、bean等等)。以及集成第三方框架时,也会看到一些spring之外的配置,例如dubbo的配置、securi...

「Spring源码分析」AOP源码解析(上篇)(spring源码深度解析(第2版))

前言前面写了六篇文章详细地分析了SpringBean加载流程,这部分完了之后就要进入一个比较困难的部分了,就是AOP的实现原理分析。为了探究AOP实现原理,首先定义几个类,一个Dao接口:1&nbs...

Spring 解析注册BeanDefinition这一篇就Over
Spring 解析注册BeanDefinition这一篇就Over

一、简介:学习过Spring框架的人一定都会听过Spring的IoC(控制反转)、DI(依赖注入)这两个概念,对于初学Spring的人来说,总觉得IoC、...

2023-03-20 14:53 xiyangw

域、模块、空间、闭包,你真的懂了吗?(模块控制域与作用域的关系)

Javascript有一个特性叫做域。尽管对于初学者来说理解域是有难度的,但我会尽力用最简单的方式让你理解域。理解域能让你的代码更优秀,减少错误,及有助于你做出更强大的模式设计。什么是域域是在运行时,...

这一次搞懂Spring自定义标签以及注解解析原理
这一次搞懂Spring自定义标签以及注解解析原理

前言在上一篇文章中分析了Spring是如何解析默认标签的,并封装为BeanDefinition注册到缓存中,这一篇就来看看对于像context这种自定义标签是如...

2023-03-20 14:53 xiyangw

前端基础进阶(七)-前端工程师最容易出错的问题-this关键字
前端基础进阶(七)-前端工程师最容易出错的问题-this关键字

我们在学习JavaScript的时候,因为对一些概念不是很清楚,但是又会通过一些简洁的方式把它给记下来,那么这样自己记下来的概念和真正的概念产生了很强的偏差.当...

2023-03-20 14:52 xiyangw

深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)
深入K8s:守护进程DaemonSet及其源码分析(k8s 进程)

建议学习:膜拜!阿里内部都在强推的K8S(kubernetes)学习指南,不能再详细了最近也一直在加班,处理项目中的事情,发现问题越多越是感觉自己的能力不足,...

2023-03-20 14:52 xiyangw

Spring 是如何解析 bean 标签的?(spring beans标签)
Spring 是如何解析 bean 标签的?(spring beans标签)

前情回顾上回「SpringIoC容器初始化(2)」说到了Spring如何解析我们定义的<bean>标签,代码跟进了一层又一层,跋山涉水,...

2023-03-20 14:52 xiyangw

快速了解JavaScript文本框操作(javascript文本框代码)
快速了解JavaScript文本框操作(javascript文本框代码)

HTML中使用<input>元素表示单行输入框和<textarea>元素表示多行文本框。HTML中使用的<input&...

2023-03-20 14:51 xiyangw

荐读|30道JavaOOP面试题,可以和面试官扯皮了
荐读|30道JavaOOP面试题,可以和面试官扯皮了

面试是我们每个人都要经历的事情,大部分人且不止一次,今天给大家准备了30道JavaOOP面试题,希望能够帮助到对Java感兴趣的同学,让大家在找工作的时候能够...

2023-03-20 14:51 xiyangw

源码系列——mybatis源码刨析总结,下(mybatis源码分析)
源码系列——mybatis源码刨析总结,下(mybatis源码分析)

接上文简答题一.1.Mybatis动态sql是做什么的?1.动态sql就是根据条件标签动态的拼接sql,包括判空,循环,拼接等2.哪些动态sql?动态sql大...

2023-03-20 14:50 xiyangw

Java面试题(第二弹)(java面试题及答案整理)
Java面试题(第二弹)(java面试题及答案整理)

1.抽象类和接口的区别?接口可以被多重implements,抽象类只能被单一extends接口只有定义,抽象类可以有定义和实现接口的字段定义默认为:public...

2023-03-20 14:50 xiyangw

mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)
mybatis3 源码深度解析-动态 sql 实现原理(sql数据库基础知识)

大纲动态sql使用示例SqlSource和BoundSql以及实现类LanguageDriver以及实现类SqlNode以及实现类动态sql解...

2023-03-20 14:50 xiyangw

第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)
第43节 Text、Comment及CDATASection(第43节 Text、Comment及CDATASection)

本内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。文本节点用Text类型表示,包含的是可以按字面解释...

2023-03-20 14:49 xiyangw

Qt读写三种文件(qt读取文件数据并赋值给变量)

第一种INI配置文件.ini文件是InitializationFile的缩写,即初始化文件。除了windows现在很多其他操作系统下面的应用软件也有.ini文件,用来配置应用软件以实现不同用户的要...

取消回复欢迎 发表评论: