uniapp小程序开发 | 从零实现一款影视类app (横向滚动和下拉刷新的实现)

2024-06-05 07:12

本文主要是介绍uniapp小程序开发 | 从零实现一款影视类app (横向滚动和下拉刷新的实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

uniapp小程序开发实战系列,完整介绍从零实现一款影视类小程序。包含小程序前端和后台接口的全部完整实现。系列连载中,喜欢的可以点击收藏。

这里介绍下我的电影小程序的完整实现过程。这个系列将会详细讲解每个步骤,包括接口设计、数据结构优化、用户体验提升等方面,帮助开发者从零开始构建一个完整的电影小程序。希望这个系列对你有所帮助,别忘了点击收藏,以便随时查阅和跟进更新内容。接下来后续的文章,还将深入探讨如何实现电影详情页以及评论功能。

该篇着重介绍下实现过程中的横向滚动和下拉刷新的实现。

电影展示界面,是个明显的横向滚动。在没实现之前,一直以为可能需要借助listView或者uni-grid组件来实现,最后发现都不行。最终仅使用内置组件的scroll-view配合flex布局就完美达到效果啦。这里总结分享下,给需要的小伙伴。

效果截图: 

在uniapp小程序开发中,实现横向滚动和下拉刷新功能是一项常见的需求,尤其是在构建电影展示界面这样的场景。

首先,我们来看看横向滚动的实现。

横向滚动(Horizontal Scrolling)

使用<scroll-view>组件,设置scroll-x属性为true,这将使内容在水平方向上滚动。

通过width和height属性控制scroll-view的尺寸,确保内容能正确显示。

为了确保内容宽度大于容器宽度,我们需要通过CSS设置display: flex和flex-wrap: nowrap,这样内容会水平排列并持续滚动。

实现代码

index.vue:

<template><view class="content">           <view class="title"><view class="title-item">影院热映</view><view class="title-more" @click="goToMore(1)">查看更多 ></view></view><scroll-view:scroll-x="true":show-scrollbar="false"class="scroll"><view class="movie-box"><view  v-for="(item, index) in hotList":key="index"@click="goToDetail(item.id)" class="movie-item"><image :src="item.imageUrl" mode="heightFix" /><view class="movie-item-title">{{ ellipsis(item.title) }}</view><view class="movie-rate"><uni-rate :readonly="true" :value="item.rate/2" size=12 active-color="#ffaa00" color="#DADADA"></uni-rate><text class="movie-rate-t">{{item.rate}}</text></view></view></view>  </scroll-view></view>
</template>

样式代码

<style scoped>.content {display: flex;flex-direction: column;align-items: center;justify-content: center;}.uni-margin-wrap {width: 690rpx;width: 100%;}.scroll{height:320rpx;width: 100%;white-space: nowrap;margin-top:15rpx;}.movie-box{display: flex;flex-direction: row;padding-left: 10rpx;padding-right: 10rpx;}.movie-item {display: flex;flex-direction: column;align-items: center;justify-content: center;width: 200rpx;height: 330rpx;margin-right: 22rpx;}.movie-item-img {border-radius: 5rpx;}.movie-item-title {color: #606266;font-size: 10rpx;margin-top: 10rpx;}.movie-rate {height: 40rpx;line-height: 40rpx;display: flex;justify-content: space-between;align-items: center;margin-bottom: 15rpx;}.movie-rate-t {margin-right: 4rpx;font-size: 8rpx;}
</style>

接口实现

以下为测试横向滚动使用的接口,获取正在热映的电影。

// 获取当前正在热映电影
export const getNowHot = async (start,count,city) => {try {console.log('getNowHot request');const response = await uni.$http.post('/movie/in_theaters',{apikey: uni.$apiKey,city:city,start:start,count:count});console.log(response);if (response.statusCode !== 200) {uni.showToast({title: '数据请求失败! ',duration: 1500,icon: 'none',});return [];}return response.data;} catch (error) {console.error('Network request failed:', error);uni.showToast({title: '网络请求失败! ',duration: 1500,icon: 'none',});return [];}
};

接口mock

以下为对今日热映电影的接口的mock(支持分页请求),在后台接口不具备的情况下方便测试。

// 界面A的Mock Data
import './better-mock/mock.mp.js'export function mockTest(){console.log('mockTest')// 今日热映 电影接口模拟const data2 = Mock.mock(uni.$http.baseUrl+'/movie/in_theaters','post',{// 属性 list 的值是一个数组,其中含有3个元素'list|10': [{'id|+1': 1,'imageUrl|+1': ['/static/hot/1.jpg','/static/hot/2.jpg', '/static/hot/3.jpg', '/static/hot/4.jpg', '/static/hot/5.jpg', '/static/hot/6.jpg'],'title|4-6': '标题','rate|1-9':1,'description|2-3':'这是描述'}],'total|20-50': 1, 'currentPage|1-5': 1, 'pageSize': 5});// 输出结果console.log(JSON.stringify(data2, null, 4));//使用四个空格缩进
}

下拉刷新的实现

在点击查看更多时,会进入今日热映页面,展示全部的热映影片。这时候就用到了下拉刷新的实现,因为数据是分页请求的,一次不可能全部加载完。

下拉刷新,分页加载的实现也很简单。在uniapp中有onReachBottom页面级别的生命周期事件。 

在uniapp中,onReachBottom 是一个页面级别的生命周期事件,当用户滚动到页面底部时触发。它的主要用途是用来实现下拉加载更多(Load More)的功能,即当用户滚动到页面的底部附近,系统自动触发该事件,开发者可以在这个事件的回调函数中加载新的数据并更新列表。

可在pages.json里定义具体页面底部的触发距离onReachBottomDistance,

比如设为50,那么滚动页面到距离底部50px时,就会触发onReachBottom事件。

注意和scroll-view滚动到底部的事件的区别,scroll-view 组件自身的滚动到底部事件与页面级别的 onReachBottom 事件有以下几点区别:

1.触发范围:

scroll-view滚动到底部事件:此事件仅限于<scroll-view>组件内部的滚动。当scroll-view的内容滚动到其容器底部时触发。

onReachBottom:这是页面级别的事件,适用于整个页面的滚动。当用户滚动到页面底部时触发,无论滚动发生在scroll-view组件内还是页面的其他可滚动区域。

2.应用场景:

scroll-view滚动到底部事件:适用于那些需要在局部滚动区域(如列表、轮播等)实现加载更多功能的场景。

onReachBottom:适用于整个页面滚动到尽头时加载更多内容,适用于页面主体内容滚动的场景。

3.实现下拉刷新:

实现下拉刷新功能通常不直接使用上述两个事件中的任何一个。下拉刷新通常通过scroll-view组件的refresher-enabled属性和相关事件来实现。

设置scroll-view的refresher-enabled属性为true来开启下拉刷新功能。

使用@refresherpulling事件监听用户下拉动作,可以在此事件中更新下拉刷新的UI状态或显示刷新进度。

使用@refresherrefresh事件处理实际的刷新逻辑,即调用接口获取新数据。

数据加载完成后,调用this.$refs.scrollview.finishPullRefresh()来结束刷新状态。

scrollview的下拉刷新示例代码片段如下:

<scroll-view scroll-y refresher-enabled @refresherpulling="onRefresherPulling" @refresherrefresh="onRefresherRefresh"ref="scrollview"><!-- 页面内容 -->
</scroll-view>
methods: {onRefresherPulling(e) {// 可以在这里根据e.detail.pullDistance等信息更新下拉刷新的UI},async onRefresherRefresh() {// 加载新数据await this.loadData();// 结束刷新状态this.$refs.scrollview.finishPullRefresh();},loadData() {// 实际的数据加载逻辑}
}

 参见文档:页面 | uni-app官网

由于这个展示在单独的一个页面,因此简单的使用页面声明周期事件onReachBottom。

完整代码:

<template><view  class="wrapper"><!-- 电影列表 --><scroll-view  :scroll-y="true":show-scrollbar="false"class="scroll"><view class="movie-box"><view v-for="(item, index) in hotList" :key="index" class="movie-item"><image class="movie-item-img" :src="item.cover"  mode="heightFix"></image><view class="movie-item-title">{{ ellipsis(item.title) }}</view><view class="movie-rate"><uni-rate :readonly="true" :value="item.rate/2" size=12 active-color="#ffaa00" color="#DADADA"></uni-rate><text class="movie-rate-t">{{item.rate}}</text></view></view></view><uni-load-more :status="listStatus" :contentText="contentText" v-if="loadStatu"></uni-load-more></scroll-view></view>
</template><script>import { getNowHot } from '@/api/home.js';export default {data() {return {	loadStatu: false, // loading是否显示listStatus: 'loading', // loading状态contentText: {contentdown: "加载更多",contentrefresh: "正在加载...",contentnomore: "我是有底线的"},pageNum: 1, // 电影列表初始页数movieInfo: [], // 电影列表hotList: [{id: 1,cover: '/static/hot/1.jpg',title: '标题提提提提提11111',description: '描述1',rate:10},{id: 2,cover: '/static/hot/2.jpg',title: '标题2',description: '描述2',rate:2},{id: 3,cover: '/static/hot/3.jpg',title: '标题3',description: '描述3',rate:8},{id: 4,cover: '/static/hot/4.jpg',title: '标题4',description: '描述4',rate:7},,{id: 5,cover: '/static/hot/5.jpg',title: '标题5',description: '描述5',rate:5}]};},onReachBottom: function() { // 页面触底触发console.log('触底’')this.getmorenews()},methods:{// 名称超出显示省略号ellipsis(value) {if (!value) return '';if (value.length > 7) {return value.slice(0, 6) + '...'}return value},// 触底之后触发函数,getmorenews() {var that = thisthat.loadStatu = trueif (that.movieInfo.length > 89) {that.listStatus = 'noMore'return}that.listStatus = 'loading'console.log('page:'+this.pageNum);getNowHot(this.pageNum,10,"郑州").then(result => {//this.swiperList = item;//that.loadStatu = falsethis.listStatus = "more";this.pageNum++;console.log("getNowHot,result:");console.log(result);that.hotList = that.hotList.concat(res.data.subjects);that.listStatus = 'loading'//this.hotList = result; });}}}
</script><style scoped lang="scss">
.wrapper {position: absolute;top: 0;bottom: 0;width: 100%;background-color: #F4F4F4;}.scroll{height:100%;width: 100%;white-space: nowrap;margin-top:10rpx;}.movie-box{display: flex;flex-direction: row;flex-wrap: wrap;padding-left: 10rpx;padding-right: 10rpx;}.movie-item {display: flex;flex-direction: column;align-items: center;justify-content: center;width: 220rpx;height: 350rpx;margin-right: 22rpx;}.movie-item-img {border-radius: 5rpx;}.movie-item-title {color: #606266;font-size: 8rpx;margin-top: 10rpx;}.movie-rate {height: 40rpx;line-height: 40rpx;display: flex;flex-direction: row;justify-content: space-between;align-items: center;margin-bottom: 15rpx;}.movie-rate-t {margin-right: 4rpx;font-size: 8rpx;}
</style>

最后,附上测试的工程代码源码。

资源下载地址:https://download.csdn.net/download/qq8864/89377440

其他资源

豆瓣 Api V2(测试版) | doubanapi

豆瓣网接口-CSDN博客

豆瓣电影API接口_电影数据api接口购买-CSDN博客

https://github.com/liulongbin1314/request-miniprogram

小程序项目(uniapp)_uniapp小程序项目-CSDN博客

使用微信小程序开发制作一个简单的电影资讯应用-CSDN博客

uni-app 使用escook/request-miniprogram插件发请求说明_request-miniprogram post-CSDN博客

小程序调用豆瓣公开接口解决办法(转) - 简书

https://feizhaojun.com/?p=3813

https://www.cnblogs.com/winchance/p/13230063.html

这篇关于uniapp小程序开发 | 从零实现一款影视类app (横向滚动和下拉刷新的实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1032409

相关文章

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2