h5应用 vue 钉钉_uniapp开发一个小视频应用(一)

uni-app 是一个使用 Vue.js 开发所有前端应用的框架,是一种终极的跨平台解决方案,这里的平台,主要指的是App平台(android、ios)、小程序平台、H5平台。开发者编写一套代码,可发布到iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉)等多个平台。

01

开发一个小视频应用

初始化项目

打开HBuilderX IDE,新建一个名称为mini-video的初始化uni-app项目,这里勾选uni-app即可创建,项目创建完成后,打开pages/index/index.vue,将中的模板内容content部分清空,将uni-app初始项目中与应用无关的东西进行清空、修改即可。

68efc47e0c4dbeb1f87cb65707f01624.png

创建底部导航栏组件

首先要弄清楚我们的uni-app已经提供了tabBar的配置,即提供了底部导航栏的,那为什么还需要自定义底部导航栏呢 ?因为uni-app提供的默认底部导航栏tabBar的背景颜色只支持十六进制,所以无法设置为透明。同时我们又需要将底部导航栏中的页面设置为tabBar页面,所以我们还是要进行tarBar的配置,而一配置tabBar,那么就会自动出现uni-app提供的默认导航栏,所以我们必须在应用启动onLaunch的时候将默认tabBar进行隐藏。

那么没有了默认导航栏,我们怎么进行tabBar页面的切换呢?我们可以通过组件设置不同的跳转方式,实现应用内各种页面之间的跳转。记住APP和微信小程序是不支持标签跳转的。

底部导航栏有五个页面: 首页(index.vue)、关注(follow.vue)、加号(添加好友friend.vue)、消息(news.vue)、我(personal.vue)。所以需要在pages中模仿index新建出剩余的四个页面,页面新建完成后,需要配置到pages.json中的tarBar中,只需要配置list即可,如:

{    "tabBar": { // 在pages.json中添加上tabBar配置,如下        "list": [            {"pagePath":"pages/index/index"},            {"pagePath":"pages/follow/follow"},            {"pagePath":"pages/friend/friend"},            {"pagePath":"pages/news/news"},            {"pagePath":"pages/personal/personal"}        ]    }}// App.vue中onLaunch的时候隐藏掉uni-app自带的tabBar    export default {        setTimeout(() => {            uni.hideTabBar(); // 隐藏tabBar        }, 1000);    }</script>

在ios和安卓App平台上运行时,会出现tabBar隐藏失败的情况,解决办法就是隐藏的时候需要添加一个1000ms左右的延迟

// 项目根目录下新建一个components目录,并在其中新建一个tab-bar.vue即自定义底部导航栏组件<template>    <view class="tab">        <navigator open-type="switchTab" url="/pages/index/index" class="tab-box">            首页        navigator>        <navigator open-type="switchTab" url="/pages/follow/follow" class="tab-box">            关注        navigator>        <view class="tab-box">            +         view>        <navigator open-type="switchTab" url="/pages/news/news" class="tab-box">            消息        navigator>        <navigator open-type="switchTab" url="/pages/personal/personal" class="tab-box">            我        navigator>    view>template><style>.tab{    height:50px;    width:100%;    position:fixed;    bottom: 0;    left: 0;    z-index: 20;}.tab-box{    float: left;    width: 20%;    color: #FFFFFF;    text-align: center;    height: 50px;    line-height: 50px;    font-size:20px}.icon-box{    width: 60%;    height: 30px;    background: #FFFFFF;    color: #000000;    margin: 10px 20%;    line-height:30px;    border-radius: 5px;    font-size: 15px;}style>

添加图标字体

添加图标字体非常简单,就是登录iconfont网站,然后创建一个图标项目,然后搜索自己需要的图标,比如加号、搜索、返回,将它们加入到项目中,然后点击下载即可,下载完成后解压,找到iconfont.css这个文件,这个就是我们要用到的图标字体的css样式,直接引入到项目中即可,为了方便使用,我们将图标字体css文件作为一个全局样式引入到App.vue组件中。使用的时候,我们只需要在需要添加图标字体的标签上,添加上"iconfont 具体的图标样式名"即可,如:

// App.vue<style>    /*每个页面公共css */    @import url("./static/iconfont.css");style>// components/tab-bar.vue<view class="tab-box">    <view class="iconfont icon-jiahao icon-box" >    view>view>

创建首页头部导航栏

首页头部导航栏,最左侧是一个搜索图标,中间是推荐和同城,右侧无内容。同样,我们的uni-app是有一个默认头部导航栏的,所以我们首先要隐藏掉默认的头部导航栏,要隐藏默认头部导航栏,我们需要在pages.json文件中设置其navigationStyle属性值为custom即自定义,如:

{    "globalStyle": {        "navigationStyle":"custom" // 设置头部导航栏为自定义模式,头部导航栏会自动消失    }}// /components/index-header.vue<template>    <view class="index-header">        <view class="iconfont icon-icon-- icon">view>         <view class="middle">             <view class="text">推荐view>|            <view class="text">同城view>        view>    view>template><style scoped>.index-header {    height: 35px;    line-height: 35px;    width: 100%;    position: fixed;    top: 25px;    left: 0;    margin: 0 auto;    background: #000000;    z-index: 20;}.icon {    position: absolute;    left: 0;    top: 0;    color: white;    width: 20%;    text-align: center;}.middle {    text-align: center;    color: white;}.text {    display: inline;    margin: 0 10px;}style>

创建视频播放组件

视频播放组件即一个全屏的页面,然后里面嵌入一个组件即可实现。这里需要特别说一下如何让页面全屏显示,我们设置页面全屏通常会让需要全屏的元素设置上width: 100%; height: 100%;可是当我们给视频播放组件根元素标签设置上width为100%,height为100%后,它并没有全屏显示,因为当样式属性值为百分数的时候,其是相对于父元素的,即是父元素宽高的100%,而此时视频播放组件的父元素是html、body,它们并没有设置宽高,所以我们需要在App.vue中设置一下全局样式,将html和body的宽高设置为100%,此后其中的子元素设置百分数的时候才会其作用。

// App.vuehtml,body {    width: 100%;    height: 100%;    margin: 0;    padding: 0;}// /components/video-player.vue<template>    <view class="video-player">        <video class="video"                :src= "video.src"                :controls="false"               :loop="true">        video>    view>template><script>    export default {        props: ["video"]    }script><style>    .video-player {        width: 100%;        height: 100%;    }    .video {        width: 100%;        height: 100%;        z-index: 19;    }style>

创建视频列表组件

视频列表组件,我们使用的是组件,里面部分则为上面的视频播放组件。

// /components/video-list.vue    <view class="video-list">        <view class="swiper-box">            <swiper class="swiper" :vertical="true">                <swiper-item v-for="(item,index) in videos" :key="index">                    <view class="swiper-item">                        <video-player                                                      :video="item"                                                    :index="index">                        video-player>                    view>                swiper-item>            swiper>        view>    view>template><script>    import VideoPlayer from "./video-player.vue";    export default {        components: {            "video-player": VideoPlayer        },        props:['list'],        data() {            return {                videos:[],            }        },        watch:{                        list(){                                this.videos=this.list;                        }                }    }script><style scoped>    .video-list {        width: 100%;        height: 100%;    }    .swiper-box{            height:100%;            width: 100%;    }    .swiper{            height:100%;            width: 100%;    }    .swiper-item {        width: 100%;        height: 100%;        background: red;    }style>

向视频列表组件传入列表数据

视频列表组件和视频播放组件都已经完成后,就可以在首页onLoad的时候获取视频数据,然后传递给视频列表组件,视频列表组件在遍历传递过来的视频列表将视频地址传入对应的视频播放组件中即可,这里采用mock数据的方式提供视频列表。

// pages/index/index.vue<template>    <view class="content">        <index-header>index-header>         <video-list :list="list">video-list>         <tab-bar>tab-bar>     view>template><script>    import TabBar from "../../components/tab-bar.vue";    import IndexHeader from "../../components/index-header.vue";    import VideoList from "../../components/video-list.vue";    export default {        components: {            "tab-bar": TabBar,            "index-header": IndexHeader,            "video-list": VideoList        },        data() {            return {                list: []            }        },        onLoad() {            this.getVideos();        },        methods: {            getVideos() {                const res = [                    {                        id: 0,                        src: "http://alimov2.a.yximgs.com/bs2/gdtPostRoll/postRoll-MTA3MDY0NDY3Mzk.mp4",                        autho: "张三",                        title: "仙娜美",                        loveNumber: 10000,                        commentNumber: 2000,                        shareNumber: 30000                    },                    {                        id: 1,                        src: "http://upmov.a.yximgs.com/upic/2019/02/13/22/BMjAxOTAyMTMyMjUxMTlfNDc4ODM2MzlfMTA3Mjc5ODU2MjhfMV8z_b_B1fbc185eaca8cc06efa2d4f713e13e8c.mp4",                        autho: "李四",                        title: "【搞笑】最强猜歌王",                        loveNumber: 40000,                        commentNumber: 5000,                        shareNumber: 60000                    },                    {                        id: 2,                        src: "http://bdmov.a.yximgs.com/bs2/gdtPostRoll/postRoll-MTA3MDk5Mjc5OTg.mp4",                        autho: "王五",                        title: "特制流泪芥末酱",                        loveNumber: 70000,                        commentNumber: 8000,                        shareNumber: 90000                    }                ];                this.list = res;            }        }    }script><style>    .content {        width: 100%;        height: 100%;    }style>

原文作者:Rolan

原文地址:http://www.wxapp-union.com/article-5582-1.html

  -福利驾到-  

拉上好友一起拼团

最高可优惠70元!!

9ab88d4cfc1c38333584cbd07d567e34.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/311143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Blazor入门

&#xff2e;&#xff2f;&#xff37;现在行动&#xff01;Blazor是一个基于C#&#xff0c; Razor和 HTML的新的Web UI框架。它通过WebAssembly运行在浏览器中。有利于使用C#而不是JavaScript构建交互式的Web UI。这篇文章演示了如何使用Blazor构建SPA应用。Blazor简化了可在任…

第七届蓝桥杯(国赛)——随意组合-dfs,next_permutation

【问题描述】 小明被绑架到X星球的巫师W那里。 其时&#xff0c;W正在玩弄两组数据 (2 3 5 8) 和 (1 4 6 7) 他命令小明从一组数据中分别取数与另一组中的数配对&#xff0c;共配成4对&#xff08;组中的每个数必被用到&#xff09;。 小明的配法是&#xff1a;{(8,7),(5,6),(…

方框加对勾怎么输入_对号“√”怎么输入到方框“□”-空格对号

对号”√”怎么输入到方框”□”内啊&#xff1f;&#xff1f;是这样的&#xff0c;我在做一个表格例如&#xff1a;1&#xff0c;是否完成。□2&#xff0c;是否已经准备好资料。□如果“是”就在方框内打对号“√”&#xff0c;不是就打错号“X”但是怎么打在方框内阿&#x…

C#桌面开发的未来WebWindow

WebWindowWebWindow是跨平台的库。Web Window的当前实验实现可在以下平台上运行&#xff1a;Windows – 需要基于Chromium的EdgeLinux – 使用WebKitMac – 需要Safari源码https://github.com/SteveSandersonMS/WebWindow.gitZeje Fork的分支&#xff1a;https://github.com/ze…

第七届蓝桥杯决赛真题 - 凑平方数-全排列+dfs+set去重

题目&#xff1a; 凑平方数 把0~9这10个数字&#xff0c;分成多个组&#xff0c;每个组恰好是一个平方数&#xff0c;这是能够 办到的。比如&#xff1a;0, 36, 5948721再比如&#xff1a; 1098524736 1, 25, 6390784 0, 4, 289, 15376 等等…注意&#xff0c;0可以作为独立的…

计算标准差分母是n还是n-1?

概述 提问&#xff1a;在我们计算某些数据标准差&#xff08;或者方差&#xff09;的时候&#xff0c;会发现有些公式分母是n&#xff0c;而有些公式的分母却是&#xff08;n-1&#xff09;&#xff0c;那么到底哪个公式才是正确的呢&#xff1f; 答案&#xff1a; 如果是算…

三调 图斑地类面积_三调对于最小上图图斑面积的要求是:

【单选题】设二维数组 A[1...m,1...n] (即 m 行 n 列)按行存储在 B[1...m*n] 中,则二维数组元素 A[i,j] 在一位数组 B 中的下标为( )【单选题】二维数组 a[1..N , 1..N] 可以按行存储或按列存储。对于数组元素 a[i,j] ( 1<i,j<N ),当( )时,在按行和按列两种存储方式下,其…

C#小游戏—钢铁侠VS太空侵略者

身为漫威迷&#xff0c;最近又把《钢铁侠》和《复仇者联盟》系列又重温了一遍&#xff0c;真的是印证了那句话&#xff1a;“读书百遍&#xff0c;其意自现”。看电影一个道理&#xff0c;每看一遍&#xff0c;都有不懂的感受~ 不知道大伙是不是也有同样的感受&#xff0c;对于…

受检异常 非受检异常_这样设计 Java 异常更优雅,赶紧学

来源&#xff1a;Lrwinlrwinx.github.io/2016/04/28/如何优雅的设计java异常/导语异常处理是程序开发中必不可少操作之一&#xff0c;但如何正确优雅的对异常进行处理确是一门学问&#xff0c;笔者根据自己的开发经验来谈一谈我是如何对异常进行处理的。由于本文只作一些经验之…

[蓝桥杯][2018年第九届真题]调手表-bfs

小明买了块高端大气上档次的电子手表&#xff0c;他正准备调时间呢。在 M78 星云&#xff0c;时间的计量单位和地球上不同&#xff0c;M78 星云的一个小时有 n 分钟。大家都知道&#xff0c;手表只有一个按钮可以把当前的数加一。在调分钟的时候&#xff0c;如果当前显示的数是…

.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(上)...

23 | 静态文件中间件&#xff1a;前后端分离开发合并部署骚操作我们先来看一下静态文件中间件有哪些能力1、支持指定相对路径2、支持目录的浏览3、支持设置默认文档4、支持多目录映射源码链接&#xff1a;https://github.com/witskeeper/geektime/tree/master/samples/StaticFi…

src获取同级目录中的图片_一个简单的Python爬虫实例:百度贴吧页面下载图片

本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。1. 概述本文主要实现一个简单的爬虫&#xff0c;目的是从一个百度贴吧页面下载图片。下载图片的步骤如下&#xff1a;获取网页html文本内容&#xff1b;分析html中图片的html标签特征&#xff0c;用正…

C++并查集的实现

编号代表每一个元素。数组par表示的是父亲的编号&#xff0c;也就是前驱。par[x] x时&#xff0c;x是所在的树的根。 代码如下&#xff1a; #include <iostream> using namespace std; const int N 100010; int par[N], ranks[N];void init(int n) { //初始化n个元素…

十问十答 Apache 许可证

Apache 许可证由 Apache Software Foundation&#xff08;ASF&#xff09;发行&#xff0c;是一个由强大社区支持的流行的被广泛部署的许可证。Apache 许可证允许你自由地使用、修改和分发任何 Apache 许可的产品&#xff0c;前提是遵循 Apache 许可的条款。01Apache 许可证的条…

(一)基于企业现金流预测的投资决策-项目介绍

项目背景 某企业想提高现金流的利用率,以便产生更大的投资收益。遇到的问题是:何如在保证更多的资金流向高收益投资的同时,不出现资金短缺的问题。 确定可用于投资的金额 Step1 预测未来的收入、支出和余额 潜在逻辑: 现金流 = 收入 - 支出当月余额(资金存量)= 上月余…

连续不等_第九讲 函数的连续性与函数的间断点

写在前面的话&#xff1a;本讲主要内容讲了连续性的定义&#xff0c;及其三个衍生的表述方式&#xff0c;函数的几类间断点。最后一个例题回顾了极限的保号性&#xff0c;是不是又有点生疏了&#xff1f;没关系&#xff0c;回过头再看看。反复研读&#xff0c;用心体会。如果有…

[蓝桥杯2015决赛]分机号-枚举(水题)

题目描述 X老板脾气古怪&#xff0c;他们公司的电话分机号都是3位数&#xff0c;老板规定&#xff0c;所有号码必须是降序排列&#xff0c;且不能有重复的数位。 比如&#xff1a;751,520,321 都满足要求&#xff0c;而766,918,201 就不符合要求。 现在请你计算一下&#xff0c…

应用程序使用统计信息 – .NET CORE(C#) WPF界面设计

本文首发地址&#xff1a;https://dotnet9.com/10546.html关键功能点抽屉式菜单圆形进度条Demo演示&#xff1a;1. 新建项目使用 VS 2019 的 .NET Core 3.1 WPF 项目模板&#xff0c;创建名为 “MobileAppUsageDashboardCore” 的项目&#xff0c;NuGet 引入 MaterialDesign 的…

正态分布-区间估计之单侧和双侧

区别 很简单,正态分布都是左右对称的&#xff0e;在左测就是的分位点是α/2,右侧是1-α/2&#xff0e; 假设一&#xff1a;双侧假设,拒绝区域在两边而且两边对称,在题目问你”是否相等?”的时候用 H0:μ&#xff1d;μ0,H1:μ≠μ0,拒绝区域&#xff1a;u的绝对值大于u1-α/…

iso qemu 安装ubuntu_基于libvirt 和QEMU在macOS安装Ubuntu

在流行的虚拟架构体系中&#xff0c;最重要的技术当然要数libvirt和QEMU了。包括Linux虚拟化技术中KVM和xen都使用了QEMU。关于Xen和KVM进行虚拟化&#xff0c;以及在Window下使用Vmware&#xff0c;VirtualBox和hyper-v构建虚拟机&#xff0c;可能大家都有过很多的尝试。今天我…