2022-06-01 分類: 網站建設
所謂“內滾動布局”,顧名思義就是主滾動條在頁面內部的布局,是相對于傳統(tǒng)的滾動而言的,例如,下圖所示滾動條,是從頭部下方開始:
傳統(tǒng)的頁面滾動,基本上是相對于整個瀏覽器窗體,例如,QQ視頻首頁:
隨著顯示器設備越大越寬越密,以及現代web技術的發(fā)展。web站點已經開始有了從傳統(tǒng)的瀑布式網頁向類桌面軟件風格站點轉變的趨勢。比方說,QQ音樂的首頁目前是這樣子的:
以后可能就會變成這樣子:
“納尼,這不就是現在的QQ音樂軟件界面截圖?”“這位同學眼神很犀利,沒錯,這就是有著全國大的正版高質量樂庫的QQ音樂PC版截圖”。
我們可以局部放大,會發(fā)現,是個實打實的內滾動布局。
不僅是QQ音樂,其他很多桌面軟件都是這種內滾動布局,比方說QQ軟件管家等等。
有此可見,一旦強交互的傳統(tǒng)web頁面桌面軟件化,內滾動布局是繞不開的一堵墻,了解之還是很有必要的。
既然是內滾動,就有必要干掉瀏覽器原生的滾動條,這個很簡單:
html { overflow: hidden; }
“然后呢?”我想了想,好像然后就沒有“然后”了,讓一個div
容器滾動就完事了。
然而,事非經過不知難,原理雖然簡單沒說頭,但是細節(jié)操作還是有些上手成本的。
為了更好理解,我們拿實例說話。最近半年一直在參與企業(yè)QQ賬戶中心改版的項目,你可以看成是企業(yè)后臺管理系統(tǒng)。這里有幾個關鍵字,一是企業(yè),二是管理系統(tǒng)。
這里為什么要強調是“企業(yè)”呢?因為企業(yè)產品的用戶一般都是購買了企業(yè)QQ產品的企業(yè)的員工,有一定IT技能的人。因此,用戶的瀏覽器的現代感就比Qzone用戶強不少。下圖為同事在2015-05-20這個愛意滿滿的日子拉的userAgent數據:
如果我們將支持CSS3 animation
的瀏覽器稱之為現代瀏覽器,可以發(fā)現,企業(yè)產品的用戶,70%~80%的用戶都是使用的現代瀏覽器。親們,近8成的用戶都是使用現代瀏覽器,這就意味著,企業(yè)產品其實可以作為現代web技術的試驗田,在為用戶提供更好體驗更高質量產品的同時,為日后其他產品的現代化改造提供了寶貴的借鑒經驗。而本文的內滾動布局,就是萬千經驗中的一小個。
“管理系統(tǒng)”意味著站點以強交互為主,會有很多類似辦公軟件的交互操作在里面。如果是更偏重瀏覽的站點,例如企業(yè)QQ官網,顯然,傳統(tǒng)的垂直瀑布式的網站是更適合的,滾動瀏覽,再滾動,再瀏覽。但是,企業(yè)管理系統(tǒng)如此龐大,操作如此頻繁,交互如此之多,傳統(tǒng)的上下式網站顯然很難讓用戶用得非常得心應手。下圖為以前企業(yè)QQ賬戶中心組織結構頁面(測試頁面)的真容:
看著此頁面,立馬讓我想起了6年前剛畢業(yè)那會的青蔥歲月,那時候的頁面的基本上就是這樣的調調,小小的空間里有著小小的世界。時代發(fā)展,再輝煌的過去,如果沒有改變,終將會被埋汰。
正是由于以上兩點,設計師設計的時候,大膽創(chuàng)新,設計成了全屏自適應、半響應、類PC軟件風格(內滾動)的管理站點,下圖為上面老頁面同樣數據的新測試頁面截圖:
回到內滾動布局本身。
新版企業(yè)賬戶中心全站,頂部以及左側固定,不跟隨滾動,右側主體內滾動,如何實現呢?
由于企業(yè)產品不用管0.4%的IE6用戶,因此,事件就變得簡單地多了。我們可以利用絕對定位元素的拉伸特性,使內滾動容器高度自適應匹配。HTML主結構示意如下:
body -- page -- header -- side -- content
其中page
扮演傳統(tǒng)頁面的角色。這是一個預留設計,防止為了滿足某些功能或交互體驗需要,一個頁面同時出現多個類似結構頁面的情況。或者這么說吧,把所有頁面內容放在一個
page
中,此時page
就好比一個可以移動的房子,回頭你跳槽來騰訊了,房子可以一起帶過來,原來的位置可以被其他房子代替。但是,你如果直接放在中,由于
只能是一個,不動產,此時想要做整體遷移,難度就較大,同時項目幾乎成型,全局修改成本高高風險大。不過凡事都有兩面性,這樣的折騰可以減少你白頭發(fā)的數目,因為你會因操勞過度頭發(fā)直接脫掉的。
page
相關CSS如下:
.page { position: absolute; top: 0; right: 0; bottom: 0; left: 0; }
應該很好理解,絕對定位,滿屏拉伸,等同于:
.page { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
由于省了好幾個字節(jié),所以我舍棄了IE6使用了上面寫法。
對于固定的頭部header
或者固定的側邊side
, 你可以使用語義明確的position:fixed
定位,或者直接使用position:absolute
,因為滾動容器跟他們平級,所以,absolute
其實就是fixed
效果。
講到這里就不得不說點題外話,很多人會遇到移動端position:fixed
的底部輸入框定位的頭疼問題,如何解決?就是使用本文介紹的內滾動布局,然后底部使用position:absolute
模擬fixed
效果。
代碼方面,同樣就是拉伸拉伸:
.header { height: 62px; position: absolute; top: 0; right: 0; left: 0; } .side { width: 200px; position: absolute; top: 62px; bottom: 0; left: 0; }
最后就是高能的content
, 還是一樣的套路:
.content { position: absolute; top: 62px; right: 0; bottom: 0; left: 200px; overflow: auto; }
主體內容全部都在content
里面玩耍。于是,一個高寬均自適應瀏覽器窗體的內滾動布局就成型了。
我們站在上帝視角審視一下內滾動布局,本質上就是滾動容器的遷移,職能下發(fā)。所以絕大部分情況下,跟我們平常玩轉頁面的路數沒什么區(qū)別。
但是,畢竟江山易主,差異還是存在的。最簡單的例子就是對滾動事件的影響。很多滾動插件,包括以前的腳本,我們可能都是這么寫的:
$(window).scroll(function() { // 跟我一起翻滾吧,騷年…… });
但是,在內滾動布局下,由于滾動的容器不是window
窗體,不是元素,因此,上面滾動事件八輩子都不會執(zhí)行。我們需要調整,由于現在,頁面的主滾動條是
.content
, 因此,我們可以:
$(".content").scroll(function() { // 跟我一起翻滾吧,騷年 again…… });
你以為事情就這么完了嗎?太天真了!以前我們的滾動條是跟瀏覽器上邊緣是靠在一起的,但是,自從變成了內滾動,滾動條是跟網站公用頭部下邊緣排排站,這會造成什么問題呢?就是一些offset
的計算要發(fā)生一些變化。舉個例子,我們希望表格頭部操作區(qū)域有類似position:sticky
效果,也就是視區(qū)內一起翻滾,要被滾出去的時候,fixed
固定,不跟隨。
此時,我們的大滾動高度值,就需要把網站頭部的高度考慮進去(傳統(tǒng)窗體滾動不需要,因為值是0
):
var maxScrollTop = $("#tableHeader").offset().top - $(".header").height();
以上這個,我們可以稱之為“變化”,與原本的實現相比無功無過,一種變化一種轉移。實際上,內滾動布局還會帶來帶有質變性質的一些特性。
基本上,是個像樣的web2.0網站都會有彈框web組件,一個黑色半透明的overlay層,上面搖曳著彈框面板,例如這樣的:
對于黑色半透明覆蓋層,傳統(tǒng)實現是這樣的:如果要兼容IE6瀏覽器,一般是absolute
絕對定位,高度由JS計算賦予;如果不需要管IE6, 則可以使用fixed
固定定位。
然而,在內滾動布局下,“賞”就出來了,就算需要兼容IE6瀏覽器,黑色半透明高寬100%自適應覆蓋也不需要任何JS計算的幫助,也不需要監(jiān)聽window
的resize
事件,直接CSS就可以搞定。很簡單:
.overlay { position: absolute; left: 0; top: 0; width: 100%; height: 100%; }
為啥一行CSS就能搞定所有場景?因為使用的是內滾動布局,如下圖示意,屏幕就這么高,滾動在里面,自然自適應:
看上去是內滾動布局帶來的一個小小的“賞”,但是,實際上,埋下了一個不小的“罰”。
隨意改變滾動容器大的問題在于,當存在覆蓋層的時候,會影響背后頁面內容的滾動。
100%尺寸的position:absolute/fixed
的覆蓋層,會覆蓋任何非元素(包括
)(包括這些元素的滾動條),因此,只要覆蓋+滾動容器改變,頁面就無法滾動。
內滾動布局是典型的改變?yōu)g覽器默認滾動容器的布局,自然覆蓋層一出現,就沒法滾動。不過這也沒什么,對吧,彈框出現時候,頁面背景沒法滾也挺好的。
但是,麻煩的事情是,如果彈框自身高度很高,卻又沒法滾動呢(瀏覽器可用高度700像素,彈框有900像素高)?
傳統(tǒng)布局下的彈框,如果高度很高,直接設置彈框容器position:absolute
就可以愉快地上下翻滾了。但是,在內滾動布局下,彈框根本就不在滾動容器里面,翻滾一說從何談起?
大危機!怎么辦!?
我們新版企業(yè)賬戶中心就遇到這個問題,我是這么解決的——overlay和dialog合體。
合體是什么意思呢?基本上,90%+的彈框組件,半透明覆蓋層overlay和彈框dialog是兩個并列的兄弟關系的獨立的元素,這種設計的好處在于overlay組件可以復用。實際上,我們要實現一個彈框效果,只要一層div標簽就可以了,核心就是使用兼容的RGBA背景色技巧,然后彈框HTML放在里面:
.container { position: absolute; top: 0; left: 0; bottom: 0; width: 100%; background-color: rgba(0,0,0,.5); filter: progid:DXImageTransform.Microsoft.gradient(startcolorstr=#7F000000,endcolorstr=#7F000000); overflow: auto; } :root .container { /* IE9 無 filter */ filter: none; }
HTML結構示意如下:
此時,彈框在一個可滾動的容器之中,媽媽再也不用擔心我不能愉快地翻滾了!
由于傳統(tǒng)窗體滾動已經深入人心,所以我們可能會覺得內滾動布局似乎有些坑;但是,如果當年是內滾動布局天下,我們又該如何看待新興的窗體滾動布局呢?然后,從產品的角度講,內滾動布局在操作如此頻繁的重交互項目中所帶來的交互體驗上的改進,要遠比經驗不足帶來的額外開發(fā)成本要大很多很多。
我相信,這種交互形式以及web布局上的創(chuàng)新一定會帶來很多正面的反饋和積極的影響,產品即將上線,我們可以拭目以待。
內滾動布局,更現代,更移動,如果您的項目合適,不妨也試試這種看似新穎的布局方式。
當前名稱:淺議內滾動布局
轉載注明:http://www.rwnh.cn/news/162379.html
成都網站建設公司_創(chuàng)新互聯,為您提供虛擬主機、關鍵詞優(yōu)化、App開發(fā)、ChatGPT、品牌網站建設、Google
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯
猜你還喜歡下面的內容