微信小程序仿哔哩哔哩视频组件

简介: 微信小程序仿哔哩哔哩视频组件

微信小程序视频组件仿照哔哩哔哩

微信小程序仿照哔哩哔哩(包含源码获取)

效果如下图

+27.png+29.png

+30.png+31.png一、项目介绍

项目为简单的小程序代码片段,不包含后端,只通过原生的小程序语言开发,使用官方原生的 video,没有使用任何的第三方的组件库,


需要的小伙伴可以自己获取项目的源代码,引入项目即可使用


视频组件video是在官方的 示例代码 的基础上改进的,其中在官方的基础上添加了如下功能:


双击播放/暂停

弹幕关闭/开启

注:由于小程序的 video 的 danmu-btn 属性的局限性,弹幕按钮,只在初始化时有效,不能动态变更,因此使用自定义的开启/关闭按钮仅仅在视频播放中一次有效(有知道解决办法的友友可以探讨一下)


二、项目结构

components(自定义组件)

Comment(评论组件)

Video-Recommend(视频推荐列表组件)

images(图片资源)

index(主页面)

三、项目说明

项目仅仅使用一个页面index实现,页面展示了video部分和video下面的区域(重点)


下面讲下如何实现自定义导航栏的滑动切换和点击切换


首先我们在 wxml 页面通过 scroll-view 标签和 swiper 标签的搭配使用实现页面可以左右切换

<view>
    <scroll-view class="scroll-x" 
                 scroll-x="true" 
                 scroll-with-animation>
        <block wx:for-items="{{tabs}}" wx:key="index">
            <view id="{{index}}" 
                  class="item {{activeIndex == index ? 'active' : ''}}" 
                  bindtap="tabClick">
                {{item}}
            </view>
        </block>
    </scroll-view>
</view>
<swiper class="swiper-box" 
        style="height:calc(100vh - 76rpx);"  
        bindchange="change" 
        current="{{activeIndex}}">
    <swiper-item>
        <scroll-view scroll-y="true" class="scroll-y">
            <!-- 一区域 -->
        </scroll-view>
    </swiper-item>
    <swiper-item>
        <scroll-view scroll-y="true" class="scroll-y">
            <!-- 二区域 -->
        </scroll-view>
    </swiper-item>
</swiper>

在 wxss 中 写出样式和点击/滑动选中的样式 active

最后在 js 中写好滑动和点击切换的逻辑

data:{
    tabs: ["简介", "评论"]
    activeIndex: 0,  // 默认选中第一个
}
tabClick: function (e) {
    var current = e.currentTarget.id;
    this.setData({
        activeIndex: current,
    });
},
change: function (e) {
    this.setData({
        activeIndex: e.detail.current,
    })
},

页面结构了解清晰了之后,就只需要引入自定义的视频推荐列表的组件和评论的组件,并且将数据从主页面传递给组件就大功告成了。


四、源码获取

github: https://github.com/OHUHO/mini-program-components

gitee: https://gitee.com/OHUHO/mini-program-components

组件目前还有很多不完善的地方,希望各位佬在使用中遇到问题能给我留言,看到了必将第一时间回复。


相关文章
|
14天前
|
小程序 数据可视化 JavaScript
微信小程序:轻松实现时间轴组件
本文介绍了如何在微信小程序中实现一个可视化时间轴组件。该组件适用于展示用户资金流动、投资结算等时间节点,帮助用户直观了解资金去向。时间轴支持自定义节点形状、显示序号、倒序排列等功能,并通过插槽灵活定义动态内容。文中详细介绍了组件的设计与使用方法,以及如何结合动态 slot 实现自定义操作。该组件为展示用户资金信息提供了美观、易用的解决方案。
41 1
微信小程序:轻松实现时间轴组件
|
13天前
|
小程序
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
微信小程序动态tabBar实现:基于自定义组件,灵活支持不同用户角色与超过5个tab自由组合(更新版)
165 1
|
14天前
|
小程序 搜索推荐 API
微信小程序:自定义关注公众号组件样式
尽管关注公众号组件的样式固定且不可修改,但产品经理的需求却需要个性化的定制。在这种情况下,我们需要寻找解决方案,以满足这些特殊需求,尽管这可能有点棘手。
29 0
微信小程序:自定义关注公众号组件样式
|
17天前
|
小程序 前端开发 JavaScript
微信小程序图表制作利器:ECharts组件的使用与技巧
微信小程序图表制作利器:ECharts组件的使用与技巧
43 1
|
14天前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
201 7
|
13天前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
262 1
|
28天前
|
小程序 前端开发 测试技术
微信小程序的开发完整流程是什么?
微信小程序的开发完整流程是什么?
80 7
ly~
|
2月前
|
存储 供应链 小程序
除了微信小程序,PHP 还可以用于开发哪些类型的小程序?
除了微信小程序,PHP 还可用于开发多种类型的小程序,包括支付宝小程序、百度智能小程序、抖音小程序、企业内部小程序及行业特定小程序。在电商、生活服务、资讯、工具、娱乐、营销等领域,PHP 能有效管理商品信息、订单处理、支付接口、内容抓取、复杂计算、游戏数据、活动规则等多种业务。同时,在企业内部,PHP 可提升工作效率,实现审批流程、文件共享、生产计划等功能;在医疗和教育等行业,PHP 能管理患者信息、在线问诊、课程资源、成绩查询等重要数据。
ly~
72 6
|
17天前
|
缓存 小程序 索引
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
uni-app开发微信小程序时vant组件van-tabs的使用陷阱及解决方案
102 1
|
23天前
|
小程序 前端开发 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【10月更文挑战第3天】随着移动互联网的发展,微信小程序凭借便捷的用户体验和强大的社交传播能力,成为企业拓展业务的新渠道。本文探讨了小程序全栈开发中的身份认证与授权机制,包括手机号码验证、微信登录、第三方登录及角色权限控制等方法,并强调了安全性、用户体验和合规性的重要性,帮助开发者更好地理解和应用这一关键技术。
40 5