经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » CSS » 查看文章
css之粘性sticky布局实现题头定位在顶部的方法_CSS教程_CSS
来源:jb51  时间:2021/2/18 14:49:53  对本文有异议

运用场景:

新需求有个项目是要做问卷调查,其中必然会涉及到很多题目,以及一个题目下需要对多个人打分,手机端滑动的时候,就会发生这种现象,划上去会忘记了题目。 所以计算一定的距离之后需要对题头进行一个定位。使滑到相对于区域的题头一直固定在顶部,方便打分。

解决思路:

1.首先想到的是fixed布局就是题头到一定距离的时候就固定在屏幕的顶部。  (可以实现,但是过程不是很丝滑)
2.sticky布局

sticky就可以很好的实现这个需求,但是需要考虑到兼容性(兼容IE)

sticky实现思路:

1.首先需要记录滑块的位置,需要监听滚动事件:

  1. window.addEventListener("scroll", this.handleScroll);
  2.  
  3. 记得组件销毁前去移出这个事件
  4. beforeDestroyed() {
  5. window.removeEventListener("scroll", this.handleScroll);
  6. }
  7.  

2.计算出每道题目的题头距离屏幕顶部的高度,并组成一个数组。

  1. // 记得给每一条题目都设置ref,我的ref就是每道题的id
  2.  
  3. -- vue简略缩写---
  4. <div
  5. :ref="question.id"
  6. v-for="(question, index) of formData.questions"
  7. :key="index"
  8. >
  9.  
  10.  
  11. // 为防止乱序问题,我还进行了一个排序
  12. ---- js -----
  13. this.topPositionArr = [];
  14. for (let key in this.$refs) {
  15. for (let idx in this.$refs[key]) {
  16. this.topPositionArr.push(this.$refs[key][idx].offsetTop);
  17. }
  18. }
  19. this.topPositionArr = [...new Set(this.topPositionArr)];
  20. this.topPositionArrtopPositionArr = this.topPositionArr.sort(
  21. (a, b) => {
  22. return a - b;
  23. }
  24. );
  25.  

3.滑动监听到的距离和获取到的题头进行一个比较,选择定位的题头。

  1. // 兼容不同的游览器 不同游览器的offsetTop的取法是不一样的
  2.  
  3. handleScroll() {
  4. this.scrollTop = document.documentElement.scrollTop
  5. ? document.documentElement.scrollTop
  6. : document.body.scrollTop;
  7. let scrollTop = this.scrollTop;
  8. // 第一题的scrollTop不变,从第二题的scrollTop开始变
  9. this.topPositionArr.forEach((item, idx) => {
  10. if (idx > 1) {
  11. this.scrollTop = scrollTop + 220;
  12. }
  13. //为什么这样做呢? 是因为iE不支持sticky布局,我们需要一个插件去协助使用
  14. if (this.scrollTop > item) {
  15. let elements = document.getElementById(`sticky${idx}`);
  16. stickyfill.add(elements);
  17. }
  18. });
  19. }
  20.  

4.IE的兼容问题

因为IE是不支持sticky布局的,所以我们需要轮子 stickyfill

  1. npm install stickyfill
  2. yarn add stickyfill

--- vue---
需要给题头的div标签一个动态的id,表示唯一性

  1. <div
  2. :id="`sticky${question.index}`"
  3. class="isSticky"
  4. >

单文件引入

  1. 在你需要的页面中引入:
  2. <script src="path/to/stickyfill.min.js"></script>
  3. var Stickyfill = require("stickyfill");
  4. var stickyfill = Stickyfill();

js文件:

  1. 具体方法看上述3
  2. let elements = document.getElementById(`sticky${idx}`);
  3. stickyfill.add(elements);

以上就可以完美的实现哦~~~
PS:如果是只需要兼容谷歌,那就不需要这么麻烦,可以直接使用stiky布局,不再需要轮子 --
可以参考看看https://www.zhangxinxu.com/wordpress/2018/12/css-position-sticky/旭鑫大大的文章

最后效果图:

到此这篇关于css之粘性sticky布局实现题头定位在顶部的方法的文章就介绍到这了,更多相关css 粘性sticky内容请搜索w3xue以前的文章或继续浏览下面的相关文章,希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号