濮阳杆衣贸易有限公司

主頁 > 知識庫 > css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法

css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法

熱門標(biāo)簽:旅游地圖標(biāo)注線路 電銷專用外呼線路 400電話唐山辦理 地圖標(biāo)注位置怎么弄圖 電話機(jī)器人鑰匙扣 廣西房產(chǎn)智能外呼系統(tǒng)推薦 電銷外呼系統(tǒng)是違法的嗎 漯河外呼調(diào)研線路 威力最大的電銷機(jī)器人

運(yùn)用場景:

新需求有個項(xiàng)目是要做問卷調(diào)查,其中必然會涉及到很多題目,以及一個題目下需要對多個人打分,手機(jī)端滑動的時候,就會發(fā)生這種現(xiàn)象,劃上去會忘記了題目。 所以計(jì)算一定的距離之后需要對題頭進(jìn)行一個定位。使滑到相對于區(qū)域的題頭一直固定在頂部,方便打分。

解決思路:

1.首先想到的是fixed布局就是題頭到一定距離的時候就固定在屏幕的頂部。  (可以實(shí)現(xiàn),但是過程不是很絲滑)
2.sticky布局

sticky就可以很好的實(shí)現(xiàn)這個需求,但是需要考慮到兼容性(兼容IE)

sticky實(shí)現(xiàn)思路:

1.首先需要記錄滑塊的位置,需要監(jiān)聽滾動事件:

window.addEventListener("scroll", this.handleScroll);

記得組件銷毀前去移出這個事件
 beforeDestroyed() {
    window.removeEventListener("scroll", this.handleScroll);
  }

2.計(jì)算出每道題目的題頭距離屏幕頂部的高度,并組成一個數(shù)組。

// 記得給每一條題目都設(shè)置ref,我的ref就是每道題的id

-- vue簡略縮寫---
<div
  :ref="question.id"
  v-for="(question, index) of formData.questions"
  :key="index"
>


// 為防止亂序問題,我還進(jìn)行了一個排序
---- js -----
 this.topPositionArr = [];
  for (let key in this.$refs) {
      for (let idx in this.$refs[key]) {
        this.topPositionArr.push(this.$refs[key][idx].offsetTop);
      }
    }
    this.topPositionArr = [...new Set(this.topPositionArr)];
    this.topPositionArrtopPositionArr = this.topPositionArr.sort(
      (a, b) => {
        return a - b;
      }
    );        

3.滑動監(jiān)聽到的距離和獲取到的題頭進(jìn)行一個比較,選擇定位的題頭。

// 兼容不同的游覽器 不同游覽器的offsetTop的取法是不一樣的

handleScroll() {
    this.scrollTop = document.documentElement.scrollTop
  ? document.documentElement.scrollTop
  : document.body.scrollTop;
  
let scrollTop = this.scrollTop;
// 第一題的scrollTop不變,從第二題的scrollTop開始變
this.topPositionArr.forEach((item, idx) => {
  if (idx > 1) {
    this.scrollTop = scrollTop + 220;
  }
  //為什么這樣做呢? 是因?yàn)閕E不支持sticky布局,我們需要一個插件去協(xié)助使用
  if (this.scrollTop > item) {
    let elements = document.getElementById(`sticky${idx}`);
    stickyfill.add(elements);
  }
});
}

4.IE的兼容問題

因?yàn)镮E是不支持sticky布局的,所以我們需要輪子 stickyfill

npm install stickyfill 
yarn add stickyfill

--- vue---
需要給題頭的div標(biāo)簽一個動態(tài)的id,表示唯一性

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

單文件引入

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

js文件:

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

以上就可以完美的實(shí)現(xiàn)哦~~~
PS:如果是只需要兼容谷歌,那就不需要這么麻煩,可以直接使用stiky布局,不再需要輪子 --
可以參考看看https://www.zhangxinxu.com/wordpress/2018/12/css-position-sticky/旭鑫大大的文章

最后效果圖:

到此這篇關(guān)于css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法的文章就介紹到這了,更多相關(guān)css 粘性sticky內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

標(biāo)簽:銅陵 綏化 焦作 湘西 無錫 湖北 試駕邀約 欽州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法》,本文關(guān)鍵詞  css,之,粘性,sticky,布局,實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于css之粘性sticky布局實(shí)現(xiàn)題頭定位在頂部的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    富宁县| 馆陶县| 宁波市| 淮北市| 河北省| 金寨县| 白银市| 南通市| 盘锦市| 准格尔旗| 铜山县| 上杭县| 台北县| 扶绥县| 合肥市| 丰镇市| 澄迈县| 旺苍县| 松桃| 驻马店市| 建水县| 公安县| 扎赉特旗| 南阳市| 绍兴县| 临潭县| 湘西| 虹口区| 蓝田县| 咸丰县| 土默特右旗| 湘潭市| 南溪县| 安溪县| 德保县| 济南市| 安西县| 黔西| 宁安市| 黄平县| 乌苏市|