微信小程序 19 视频列表

19.1 获取视频列表数据


接口:http://localhost:3000/video/group?id=58100

  1. 该接口需要 登录的 cookies,需要我们 要略微 改动下 request 方法。

首先我们要知道,很多的接口可能需要 登录的 cookie,也就是 我们 要 传入 一下 header。那么 wx.request 是支持 这个功能的,只要在 传参里面 写入 一个 header 的 json 就行了。

import config from "./config";
export default (url,data = {type:2},method = "GET") => {
    return new Promise((resolve, reject) => {
        wx.request({
            url: config.host + url,
            data,
            method,
            success:(res) => {
                if(url == "login/cellphone"){
                    wx.setStorage({
                        key: 'cookies',
                        data: res.cookies
                    })
                }
                // 修改 Promise 状态 为 成功状态
                resolve(res.data);// 成功后要 返回什么数据
                //你就在 括号里 传入什么数据即可
            },
            fail:(err) => {
                reject(err);
            }
        })
    });
}

这样,我们 就能 在 每次登陆后,把 cookies 保存到 本地了。

  1. 获取到 视频列表
// 获取视频列表数据
    async getVideoList(navId) {
        // http://localhost:3000/video/group?id=58100
        let videoListData = await request('video/group', {id: navId});
    },

    /**
     * 生命周期函数--监听页面加载
     */ async getVideoGroupListData() {
        let videoGroupListData = await request("video/group/list",{});
        this.setData({
            videoGroupList: videoGroupListData.data.slice(0, 14),
            navId: videoGroupListData.data[0].id
        });
        this.getVideoList(this.data.navId);
    },
    onLoad(options) {
         // 获取 导航标签的数据
        this.getVideoGroupListData();
    },

19.2 视频列表区域的搭建

  1. 首先 我们 发现 datas 里面 没有 明显的 wx:key 就是唯一标识。所以我们 要手动添加一个 唯一标识 id。然后 我们 还要 通过 datas 每个元素里面的 vid 获取到 视频的 地址。
    获取视频url 的接口:http://localhost:3000/video/url?id=A24C8DF6283CD4356D86F92652989573
// pages/login/login.js
import request from "../../utils/request";

Page({

    /**
     * 页面的初始数据
     */
    data: {
        videoGroupList: [],
        navId:"", // 导航的标识
        videoList: [],
        videoURLs:[], // 每个标签的 视频 url
    },

    // 点击标签栏
    changeNav(event){
        let navId = event.currentTarget.id;
        this.setData({
            navId: navId
        });
        this.getVideoList(this.data.navId);
    },

    // 获取视频列表数据
    async getVideoList(navId) {
        // http://localhost:3000/video/group?id=58100
        let videoListData = await request('video/group', {id: navId});
        let index = 0;
        let videoList = videoListData.datas.map(item => {
            item.id = index++; // 每个数组里 没有 id 这个 属性,那么这里 写了 id
            // 那么 就会 自动写入。
            return item;
        })
        let videoURLs = [];
        for(let i = 0; i < videoListData.datas.length; ++i){
            // http://localhost:3000/video/url?id=A24C8DF6283CD4356D86F92652989573
            let videoURL = await request("video/url",{id: videoListData.datas[i].data.vid});
            videoURLs.push(videoURL.urls[0].url);
        }
        this.setData({
            videoList: videoListData.datas,
            videoURLs: videoURLs
        });
    },

    /**
     * 生命周期函数--监听页面加载
     */ async getVideoGroupListData() {
        let videoGroupListData = await request("video/group/list",{});
        this.setData({
            videoGroupList: videoGroupListData.data.slice(0, 14),
            navId: videoGroupListData.data[0].id
        });
        this.getVideoList(this.data.navId);
    },
    onLoad(options) {
         // 获取 导航标签的数据
        this.getVideoGroupListData();
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady() {

    },

    /**
     * 生命周期函数--监听页面显示
     */
    onShow() {

    },

    /**
     * 生命周期函数--监听页面隐藏
     */
    onHide() {

    },

    /**
     * 生命周期函数--监听页面卸载
     */
    onUnload() {

    },

    /**
     * 页面相关事件处理函数--监听用户下拉动作
     */
    onPullDownRefresh() {

    },

    /**
     * 页面上拉触底事件的处理函数
     */
    onReachBottom() {

    },

    /**
     * 用户点击右上角分享
     */
    onShareAppMessage() {

    }
})
<view class="videoContainer">
<!--    头部区域-->
    <view class="header">
        <image src="/static/images/video/video.jpg"></image>
        <view class="search">
            搜索商品
        </view>
        <image src="/static/images/logo.png"></image>
    </view>

<!--    导航区域-->
    <scroll-view scroll-x="true" class="navScroll" enable-flex="true">
        <view class="navItem" wx:for="{{videoGroupList}}" wx:key="id">
            <view class="navContent {{navId == item.id? 'active':''}}" bindtap="changeNav" id="{{item.id}}">
                {{item.name}}
            </view>
        </view>
    </scroll-view>
<!--    视频列表区域-->
    <scroll-view scroll-y="true">
        <view class="videoItem" wx:for="{{videoList}}" wx:key="id">
            <video src="{{videoURLs[index]}}"></video>
            <view class="content">{{item.data.title}}</view>
            <view class="footer">
                <image class="avatar" src="{{item.data.creator.avatarUrl}}"></image>
                <text class="nickName">{{item.data.creator.nickname}}</text>
                <view class="comments_praised">
                    <text class="item">
                        <text class="iconfont icon-weiguanzhu"></text>
                        <text class="count">{{item.data.praisedCount}}</text>
                    </text>
                    <text class="item">
                        <text class="iconfont icon-pinglun"></text>
                        <text class="count">{{item.data.commentCount}}</text>
                    </text>
                    <button open-type="share" class="item btn">
                        <text class="iconfont icon-gengduo"></text>
                    </button>
                </view>
            </view>
        </view>
    </scroll-view>
</view>


.videoContainer .header {
    display: flex;
    margin: 20rpx 0;
}


.videoContainer .header image {
    width: 60rpx;
    height: 60rpx;
}

.videoContainer .header .search {
    border: 1rpx solid #eee;
    flex: 1;
    /*flex-grow 可拉伸 flex-shrink 可压缩 flex-basis 设置当前元素的宽度*/
    /*flex 默认三个值: flex-grow(0) flex-shrink(1) flex-basis(auto) 也就是说它不支持 拉伸*/
    /*flex: 1 之后,就是 flex-grow(1) flex-shrink(1) flex-basis(0%)*/

    /*当 flex: 1 后,父元素 宽度 就会变为 100 %,也就不是 你设定的那个值了。*/
    /*flex-basis(auto) 意思是说 首先 以 设定的 宽度 为 主,如果比较大的话,那么 其它元素可能被压缩。
    但 绝对不会 超出 页面的宽度。如果比较小的话,会被 自适应。*/
    font-size: 26rpx;
    text-align: center;
    line-height: 60rpx;
    margin: 0 20rpx;
    color: #d43c33;
    border-radius: 20rpx;
}

/*导航区域*/
.navScroll {
    display: flex;
    white-space: nowrap; /*不让子元素 换行*/
    height: 68rpx;
}

.navScroll .navItem {
    padding: 0 30rpx;
    font-size: 28rpx;
    height: 60rpx;
    line-height: 60rpx;
}
.navItem .active {
    border-bottom: 1rpx solid #d43c33;
}

/* 视频列表*/

.videoItem {
    padding: 0 3%;
}

.videoItem video {
    width: 100%;
    height: 360rpx;
    border-radius: 10rpx;
}

.videoItem .content {
    font-size: 26rpx;
    height:80rpx;
    line-height: 80rpx;
    max-width: 500rpx;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* footer */
.footer {
    border-top: 1rpx solid #eee;
    padding: 20rpx 0;
}
.footer .avatar {
    width: 60rpx;
    height: 60rpx;
    border-radius: 50%;
    vertical-align: middle;
}

.footer  .nickName {
    font-size: 26rpx;
    vertical-align: middle;
    margin-left: 20rpx;
}

.footer .comments_praised {
    float: right;
}

.comments_praised .btn {
    display: inline;
    padding: 0;
    background-color: transparent;
    border-color: transparent;
}

.comments_praised .btn:after {
    border: none;
}

.comments_praised .item {
    margin-left: 50rpx;
    position: relative;
}

.comments_praised .item .count {
    position: absolute;
    top: -20rpx;
    font-size: 20rpx;
}

在这里插入图片描述

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,以下是微信小程序视频播放器项目文档的主要内容: 1. 项目概述 本项目是一款基于微信小程序平台的视频播放器应用。用户可以在小程序中观看在线视频和本地视频,并且支持视频缓存和下载等功能。 2. 功能需求 2.1 在线视频播放 用户可以通过搜索或浏览视频列表,选择在线视频进行播放。 2.2 本地视频播放 用户可以在本地视频库中选择已经下载的视频进行播放。 2.3 视频缓存和下载 用户可以将在线视频进行缓存和下载,以便在没有网络连接的情况下进行观看。 2.4 播放控制和交互 用户可以通过视频播放控制面板,控制播放进度、音量、播放模式等,同时还可以进行全屏播放、分享和评论等操作。 3. 技术实现 3.1 使用开源视频播放库 本项目使用了开源的 weui-video 和 wx-video 库,它们提供了常用的视频播放功能和接口,包括视频加载、播放、暂停、跳转、全屏等。 3.2 视频缓存和下载 本项目使用了微信小程序提供的 wx.downloadFile 接口实现视频的缓存和下载功能。同时,为了提高用户体验,本项目使用了本地存储技术,将下载的视频保存在用户的手机上,以便在没有网络连接的情况下进行观看。 3.3 播放控制和交互 本项目使用了微信小程序提供的组件和接口,实现了视频播放控制面板的显示和隐藏、全屏播放、音量控制、进度条拖动等操作。同时,本项目还使用了微信小程序提供的评论和分享接口,增加了用户的交互体验。 4. 性能优化 4.1 视频缓存和下载优化 为了提高视频缓存和下载的速度和流畅度,本项目使用了多线程下载技术和断点续传技术,同时还对视频文件进行了压缩和优化。 4.2 界面渲染和响应优化 为了提高用户体验,本项目对界面的渲染和响应速度进行了优化,使用了异步加载和懒加载等技术,减少了用户等待时间和页面卡顿现象。 以上就是微信小程序视频播放器项目文档的主要内容,如果您有其他问题或需要更多指导,请随时向我提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值