position:sticky 的使用

效果

如果你想想做这样一个滚动跟随。那你肯定第一时间想到的一定是 position:fixed; 这个css 属性,然后加上一段js 的代码。

这个方式是可以的对于pc 浏览器和Android 浏览。但是对于ios 设备上的浏览器来说,它是不好的,它的反应会很慢,当你的滚动已经达到了你想要它浮起来的时候,它却没有,超出好多才浮到顶部。当然这并非是你因你的js 代码写的不够好。

此时,你就应该用 position:sticky 这个样式了。

你只需要这样做:

判断浏览器是否支持sticky 这个属性,如果支持,给想要浮动跟随的 DOM 加上

.sticky{
    position: -webkit-sticky;
    position: sticky;
    top: 0;
    z-index: 20;
}

这样一个样式就好了,不需要js 代码。

不支持的设备你就需要用 position:fixed; 的了,然后加上js 的判断代码,这里就不说js 代码了。

一个判断是否支持sticky 的方式:

var sticky = (function () {
                 var vendorList = ['', '-webkit-', '-ms-', '-moz-', '-o-'],
                      vendorListLength = vendorList.length,
                      stickyElement = document.createElement('div');

                  for (var i = 0; i < vendorListLength; i++) {
                      stickyElement.style.position = vendorList[i] + 'sticky';
                      if (stickyElement.style.position !== '') {
                          return true;
                      }
                  }
                  return false;
              })();
Caniuse 兼容图
_1491012507873.png

由此图可以看出也并不是所有的 Android 设备 不支持 , ios 设备 也并非全部支持。所以根据设备来判断,可能有误差。可以说高级浏览器是支持。

备注

1、 使用sticky 样式的 元素 的 父级 及 其 祖先元素 的 overflow 得是 默认的 visible;
2、 父级 及 其 祖先元素 高度 与其 一样高,是没有效果的。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,840评论 1 92
  • 如果你想想做这样一个滚动跟随。那你肯定第一时间想到的一定是position:fixed;这个css 属性,然后加上...
    何暖暖阅读 1,090评论 0 0
  • 一:在制作一个Web应用或Web站点的过程中,你是如何考虑他的UI、安全性、高性能、SEO、可维护性以及技术因素的...
    Arno_z阅读 1,238评论 0 1
  • ◆方法◆ 我先讲结论方法。 假设你初入门,要去学一门技术。那么: 1. How:去找专家的 “实作方法” 课、“实...
    新生大学阅读 643评论 0 11
  • 若还把时光一味的肆意挥霍 那些本来就存在的差距只会越来越大 大到有一天你再想往上爬却发现再也没有可以缩小的空间 ...
    JoJo777阅读 223评论 0 0