新聞中心
Flutter:手把手教你使用滾動(dòng)型列表組件:ListView
ListView的基礎(chǔ)創(chuàng)建使用有三種方式:
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對(duì)這個(gè)行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡(jiǎn)單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名申請(qǐng)、網(wǎng)站空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、中江網(wǎng)站維護(hù)、網(wǎng)站推廣。
通過默認(rèn)構(gòu)造函數(shù)來創(chuàng)建列表,應(yīng)用場(chǎng)景 = 短列表
這種方式創(chuàng)建的列表存在一個(gè)問題:對(duì)于那些長(zhǎng)列表或者需要較昂貴渲染開銷的子組件,即使還沒有出現(xiàn)在屏幕中但仍然會(huì)被ListView所創(chuàng)建,這將是一項(xiàng)較大的開銷,使用不當(dāng)可能引起性能問題甚至卡頓。
長(zhǎng)列表
列表子項(xiàng)之間需要分割線
ListView的進(jìn)階使用主要包括:下拉刷新 上拉加載
在Flutter中,ListView結(jié)合RefreshIndicator組件實(shí)現(xiàn)下拉刷新
通過包裹一層RefreshIndicator,自定義onRefresh回調(diào)方法實(shí)現(xiàn)
方式有兩種:
通過ListView.controller屬性可以判斷ListView是否滑動(dòng)到了底部,再進(jìn)行上拉加載
NotificationListener是一個(gè)Widget,可監(jiān)聽子Widget發(fā)出的Notification
ListView在滑動(dòng)時(shí)中會(huì)發(fā)出ScrollNotification類型的通知,可通過監(jiān)聽該通知得到ListView的滑動(dòng)狀態(tài),判斷是否滑動(dòng)到了底部,從而進(jìn)行上拉加載
NotificationListener有一個(gè)onNotification屬性,定義了監(jiān)聽的回調(diào)方法,通過它來處理加載更多邏輯
不定期分享關(guān)于 安卓開發(fā) 的干貨,追求 短、平、快 ,但 卻不缺深度 。
Flutter 可滾動(dòng)組件 之 SingleChildScrollView (十五)
SingleChildScrollView 源碼定義如下:
需要注意的是, 通常 SingleChildScrollView 只應(yīng)在期望的內(nèi)容不會(huì)超過屏幕太多時(shí)使用 ,這是因?yàn)?SingleChildScrollView 不支持基于 Sliver 的延遲加載模型,所以如果預(yù)計(jì)視口可能包含超出屏幕尺寸太多的內(nèi)容時(shí),那么使用 SingleChildScrollView 將會(huì)非常昂貴(性能差),此時(shí)應(yīng)該使用一些支持Sliver延遲加載的可滾動(dòng)組件,如 ListView 。
示例1
下面是一個(gè)將大寫字母 A-Z 沿垂直方向顯示的例子,由于垂直方向空間會(huì)超過屏幕視口高度,所以我們使用SingleChildScrollView:
示例2
示例3 - 橫向滾動(dòng)
Flutter ScrollView(滾動(dòng)視圖)
ScrollView 是一個(gè)帶有滾動(dòng)的視圖組件。
ScrollView 由三部分組成:
ScrollView 有以下常用屬性:
注:ScrollView 是一個(gè)抽象類,通常使用 CustomScrollView。
SliverAppBar 可以實(shí)現(xiàn)背景,標(biāo)題,頂部導(dǎo)航欄聯(lián)動(dòng),漸隱漸出動(dòng)畫。
分享名稱:flutter滾動(dòng)導(dǎo)航,flutter滾動(dòng)條
標(biāo)題網(wǎng)址:http://www.ef60e0e.cn/article/dscdsec.html