99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区

訂閱本欄目 RSS您所在的位置: 深山工作室 > uni-app > 正文

uni-app實現上拉加載,下拉刷新(下拉帶動畫)

2020/9/15 15:20:52 字體: 瀏覽 8153

直接展示代碼,uni-app的上拉加載動畫

1 . 在pages.json添加允許下拉刷新
    {
        "path":"pages/lookuser/lookuser",
        "style":{
            "navigationBarTitleText":"用戶日志",
            "enablePullDownRefresh": true//就是這個
        }
    }


2. 上拉加載更多組件
比如把組件放在component下了component/uni-load-more.vue


<template>
<view class="load-more">
<view class="loading-img" v-show="loadingType === 1 && showImage">
<view class="load1">
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
</view>
<view class="load2">
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
</view>
<view class="load3">
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
<view :style="{background:color}"></view>
</view>
</view>
<text class="loading-text" :style="{color:color}">
{{loadingType === 0 ? contentText.contentdown : (loadingType === 1 ? contentText.contentrefresh : contentText.contentnomore)}}</text>
</view>
</template>

<script>
export default {
name: "load-more",
props: {
loadingType: {
//上拉的狀態:0-loading前;1-loading中;2-沒有更多了
type: Number,
default: 0
},
showImage: {
type: Boolean,
default: true
},
color: {
type: String,
default: "#777777"
},
contentText: {
type: Object,
default () {
return {
contentdown: "上拉顯示更多",
contentrefresh: "正在加載...",
contentnomore: "沒有更多數據了"
};
}
}
},
data() {
return {}
}
}
</script>

<style>
.load-more{display:flex;flex-direction:row;height:80upx;align-items:center;justify-content:center;}
.loading-img{height:24px;width:24px;margin-right:10px;}
.loading-text{font-size:28upx;color:#777777;}
.loading-img>view{position:absolute;}
.load1,.load2,.load3{height:24px;width:24px;}
.load2{transform:rotate(30deg);}
.load3{transform:rotate(60deg);}
.loading-img>view view{width:6px;height:2px;border-top-left-radius:1px;border-bottom-left-radius:1px;background:#777;position:absolute;opacity:0.2;transform-origin:50%;-webkit-animation:load 1.56s ease infinite;}
.loading-img>view view:nth-child(1){transform:rotate(90deg);top:2px;left:9px;}
.loading-img>view view:nth-child(2){-webkit-transform:rotate(180deg);top:11px;right:0px;}
.loading-img>view view:nth-child(3){transform:rotate(270deg);bottom:2px;left:9px;}
.loading-img>view view:nth-child(4){top:11px;left:0px;}
.load1 view:nth-child(1){animation-delay:0s;}
.load2 view:nth-child(1){animation-delay:0.13s;}
.load3 view:nth-child(1){animation-delay:0.26s;}
.load1 view:nth-child(2){animation-delay:0.39s;}
.load2 view:nth-child(2){animation-delay:0.52s;}
.load3 view:nth-child(2){animation-delay:0.65s;}
.load1 view:nth-child(3){animation-delay:0.78s;}
.load2 view:nth-child(3){animation-delay:0.91s;}
.load3 view:nth-child(3){animation-delay:1.04s;}
.load1 view:nth-child(4){animation-delay:1.17s;}
.load2 view:nth-child(4){animation-delay:1.30s;}
.load3 view:nth-child(4){animation-delay:1.43s;}
@-webkit-keyframes load{0%{opacity:1;}
100%{opacity:0.2;}
}
</style>

3. 在頁面上調用組件


<template>
    <view style="flex: 1;">
<view v-for="(item, index) in newsList" class="newslist">{{item}}</view>
<!--3使用組件 -->
<uni-load-more  :loadingType="loadingType" :contentText="contentText" ></uni-load-more>
</view>
</template>

<script>
//1引入組件 uni-load-more.vue
import uniLoadMore from '../../component/uni-load-more.vue';

var _self,
page = 1,
timer = null;
// 定義全局參數,控制數據加載

export default {
    components: {//2注冊組件
        uniLoadMore
    },
    data: {
        newsList: [],
        loadingText: '加載中...',
        loadingType: 0,//定義加載方式 0---contentdown  1---contentrefresh 2---contentnomore
        contentText: {
            contentdown:'上拉顯示更多',
            contentrefresh: '正在加載...',
            contentnomore: '沒有更多數據了'
        }
    },
    onLoad: function() {
        _self = this;
//頁面一加載時請求一次數據
        this.getnewsList();
    },
    onPullDownRefresh: function() {
//下拉刷新的時候請求一次數據
        this.getnewsList();
    },
    onReachBottom: function() {
//觸底的時候請求數據,即為上拉加載更多
//為了更加清楚的看到效果,添加了定時器
        if (timer != null) {
            clearTimeout(timer);
        }
        timer = setTimeout(function() {
            _self.getmorenews();
        }, 1000);

// 正常應為:
// _self.getmorenews();
    },
    methods: {
        getmorenews: function() {
            if (_self.loadingType !== 0) {//loadingType!=0;直接返回
                return false;
            }
            _self.loadingType = 1;
            uni.showNavigationBarLoading();//顯示加載動畫
            uni.request({
                url:'https://demo.hcoder.net/index.php?user=hcoder&pwd=hcoder&m=list1&page=' + page,
                method: 'GET',
                success: function(res) {
                    console.log(JSON.stringify(res));
                    if (res.data == null) {//沒有數據
                        _self.loadingType = 2;
                        uni.hideNavigationBarLoading();//關閉加載動畫
                        return;
                    }
                    page++;//每觸底一次 page +1
                    _self.newsList = _self.newsList.concat(res.data.split('--hcSplitor--'));//將數據拼接在一起
                    _self.loadingType = 0;//將loadingType歸0重置
                    uni.hideNavigationBarLoading();//關閉加載動畫
                }
            });
        },
        getnewsList: function() {//第一次回去數據
            page = 1;
            this.loadingType = 0;
            uni.showNavigationBarLoading();
            uni.request({
                url: 'https://demo.hcoder.net/index.php?user=hcoder&pwd=hcoder&m=list1&page=1',
                method: 'GET',
                success: function(res) {
                    page++;//得到數據之后page+1
                    _self.newsList = res.data.split('--hcSplitor--');
                    uni.hideNavigationBarLoading();
                    uni.stopPullDownRefresh();//得到數據后停止下拉刷新
                }
            });
        }
    }
};
</script>
<style>
.newslist{padding:10px;line-height:60px;font-size:28px;}
.loading{text-align:center;line-height:80px;}
</style>


直接復制過去就能調用了,趕快試試吧

來源地址:https://blog.csdn.net/qq_39197547/article/details/84832913

后一頁:沒有了
相關閱讀
火狐Mozilla Firefox出現:無法載入您的Firefox配置文件 它可能已經丟失 或是無法訪問 問題解決集合處理辦法
圣誕節12.5號,白雪天地留言板模板
httpd.ini偽靜態網站分享到微信好友微信朋友圈鏈接打不開報404錯誤的解決辦法
深山旅行社網站管理系統 v1.6
諸城現代旅行社有限公司
蒸汽消音器
利用css實現圖片選中后顯示文字與圖片效果
ASP中控制輸出字符串的長度
共有0條關于《uni-app實現上拉加載,下拉刷新(下拉帶動畫)》的評論
發表評論
正在加載評論......
返回頂部發表評論
呢 稱:
表 情:
內 容:
評論內容:不能超過 1000 字,需審核,請自覺遵守互聯網相關政策法規。
驗證碼: 驗證碼 
網友評論聲明,請自覺遵守互聯網相關政策法規。

您發布的評論即表示同意遵守以下條款:
一、不得利用本站危害國家安全、泄露國家秘密,不得侵犯國家、社會、集體和公民的合法權益;
二、不得發布國家法律、法規明令禁止的內容;互相尊重,對自己在本站的言論和行為負責;
三、本站對您所發布內容擁有處置權。

更多信息>>欄目類別選擇
百度小程序開發
微信小程序開發
微信公眾號開發
uni-app
asp函數庫
ASP
DIV+CSS
HTML
python
更多>>同類信息
uni-app開發表單input組件的一些規則說明自己預留使用
uni-app:使用uni.downloadFile下載word或pdf文件并保存到手機
小程序中利用addPhoneContact將聯系人的信息添加到手機通訊錄支持保存聯系人頭像
微信小程序打開客服提示:該小程序提供的服務出現故障,請稍后重試
微信小程序客服會話只能過button讓用戶主動觸發
uni-app開發微信小程序使用button的open-type為contact調用微信客服不能用view或者js調用
更多>>最新添加文章
dw里面查找替換使用正則刪除sqlserver里面的CONSTRAINT
Android移動端自動化測試:使用UIAutomatorViewer與Selenium定位元素
抖音直播音掛載小雪花 懂車帝小程序
javascript獲取瀏覽器指紋可以用來做投票
火狐Mozilla Firefox出現:無法載入您的Firefox配置文件 它可能已經丟失 或是無法訪問 問題解決集合處理辦法
在Android、iOS、Windows、MacOS中微信小程序的文件存放路徑
python通過代碼修改pip下載源讓下載庫飛起
python里面requests.post返回的res.text還有其它的嗎
更多>>隨機抽取信息
微信公眾平臺
深山行者留言系統V3.1
在iframe窗口中打開鏈接
工作室網站改版計劃
全部功能介紹
黃河龍城2015最幸福情侶投票選舉
99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区
  • <li id="6qmi0"></li>
  • <li id="6qmi0"><source id="6qmi0"></source></li>
    久久久久久久波多野高潮日日| 老司机午夜精品视频| 国产亚洲精品自在久久| 国产一区激情| 亚洲成人18| 狠狠色综合色区| 久久成人亚洲| 99riav1国产精品视频| 亚洲一区二区三区四区中文| 成人激情直播| 午夜在线精品偷拍| 国产日韩综合| 亚洲人成毛片在线播放女女| 欧美一区视频| 日韩精品欧美在线| 日本一区免费看| 牛人盗摄一区二区三区视频| 国产在线精品一区二区三区》| 国产精品日本欧美一区二区三区| 极品日韩av| 伊甸园精品99久久久久久| 欧美精选一区| 欧美日韩视频| 欧美午夜精品| 一区精品在线| 国产一区二区高清不卡| 亚洲国产高清一区二区三区| 亚洲一级影院| 国产视频亚洲| 久久一区精品| 国产日韩精品一区观看| 国内精品国语自产拍在线观看| 欧美综合77777色婷婷| 99re资源| 一区二区视频在线观看| 久久精品ww人人做人人爽| 亚洲综合精品四区| 国产农村妇女精品一二区| 一本色道久久综合亚洲精品高清| 欧美视频亚洲视频| 亚洲黄色免费| 亚洲一区二区在线免费观看| 国产精品美女| 国产精品视频在线免费观看| 狠狠爱一区二区三区| 久久青青草综合| 日韩欧美一区二区三区四区| 欧美在线首页| 亚洲国产日韩综合一区| 亚洲免费网站| 国内精品二区| 少妇特黄a一区二区三区| 永久久久久久| 91久久极品少妇xxxxⅹ软件| 国产农村妇女精品一二区| 99精品国产高清在线观看| 免费在线成人av电影| 欧美在线影院| 美女国产一区| 欧美日韩一区综合| 国产一区二区三区无遮挡| 亚洲一区区二区| 裸模一区二区三区免费| 你懂的国产精品| 久久天堂国产精品| 日本a级片久久久| 精品不卡一区二区三区| 国产精品久久精品视| 一区二区三区四区欧美日韩| 99视频+国产日韩欧美| 国产中文一区二区| 欧美激情综合色综合啪啪| 每日更新成人在线视频| 日韩av一区二区三区美女毛片| 亚洲国产一区二区三区在线播 | 神马影院我不卡| 亚洲精品激情| 奇米精品在线| 裸体丰满少妇做受久久99精品| 日韩一二三区不卡在线视频| 国产偷久久久精品专区| 少妇精品久久久久久久久久| 国产日韩欧美二区| 性欧美videosex高清少妇| 国产久一道中文一区| 在线视频不卡一区二区| 国产精选在线观看91| 亚洲成人自拍视频| 欧美一区三区二区在线观看| 新67194成人永久网站| 欧美一区不卡| 国产综合色一区二区三区| 国产日韩欧美一区二区| 亚洲欧美日韩不卡一区二区三区| 久久这里只有| 亚洲黄网站黄| 午夜天堂精品久久久久| 免费在线观看91| 草莓视频一区| 国产亚洲毛片在线| 欧美日本在线| 小说区图片区图片区另类灬| 国产精品麻豆免费版| 亚洲一区区二区| 亚洲精品在线视频观看| 午夜国产精品视频免费体验区| 欧美二区在线| 国产伦精品一区二区三区四区免费| 亚洲另类黄色| 伊人激情综合| 欧美另类视频| 在线视频不卡国产| 视频一区二区综合| 日本在线播放不卡| 欧美亚洲免费高清在线观看| 国产欧美精品一区二区三区| 91成人免费看| 久久蜜桃精品| 97人人做人人人难人人做| 欧美亚洲自偷自偷| 国产精品日本| 久久国产高清| 欧美亚洲免费高清在线观看| 国产精品有限公司| 亚洲在线免费| 美女久久网站| 高清不卡日本v二区在线| 久久一日本道色综合久久| 羞羞视频在线观看欧美| 免费欧美在线| 99久久伊人精品影院| 国产精品一区二区三区在线| 国产91免费视频| 久久久久综合一区二区三区| 欧美日韩国产综合在线| 日本在线成人一区二区| 在线国产伦理一区| 韩国av一区| 国产精品亚洲综合| 99理论电影网| 欧美日韩综合网| 欧美高清一区| 99国产精品久久久久久久| 美女日韩在线中文字幕| 91久久极品少妇xxxxⅹ软件| 国产三区精品| 亚洲日本精品一区| 亚洲性图久久| 久久综合九色综合欧美狠狠| 精品蜜桃一区二区三区| 少妇免费毛片久久久久久久久| 午夜视频一区| 美女国产一区| 欧美理论一区二区| 欧美日韩国产精品一区二区亚洲| 一区在线免费观看| 成人xxxxx色| 天天综合色天天综合色hd| 亚洲欧洲久久| 国产三区精品| 久久久久久九九| 亚洲激情av| 九色91在线视频| 国产一区二区三区四区hd| 444亚洲人体| 在线看无码的免费网站| 亚洲免费在线| 欧美亚洲免费高清在线观看 | 国产精品va| 国产高清一区视频| 欧美三区美女| 久久久久se| 一区二区久久| 亚洲巨乳在线观看| 久久久水蜜桃av免费网站| 亚洲 日韩 国产第一区| 久久青青草综合| 精品成人一区| 欧洲在线视频一区| 久久九九精品| 国内揄拍国内精品久久| 久久久精品国产一区二区三区| 亚洲激情一区二区| 日本午夜精品一区二区| 免费欧美在线| 极品日韩av| 色乱码一区二区三在线看| 97视频中文字幕| 永久域名在线精品| 亚洲bbw性色大片| αv一区二区三区| 黄色av一区| 性高湖久久久久久久久| 欧美激情成人在线| 国产精品免费一区二区| 日韩视频不卡| 一区二区视频在线免费| 麻豆久久久9性大片| 国产日韩一区欧美| 先锋在线资源一区二区三区|