VUE哔哩哔哩移动端项目使用vant 实现发布功能(上传文件)

本文主要是介绍VUE哔哩哔哩移动端项目使用vant 实现发布功能(上传文件),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

bilibili发布页面主要有:发布按钮、多行文本框、一个上传图片的按钮(此处使用了vant)

在这里插入图片描述

组件里面的头部有:左返回按钮(使用vant)、发布按钮

<div class="top"><van-icon name="arrow-left" class="top-lef" @click="go" /><!-- 给按钮绑定一个class 如果computed返回的是true 就调用rel-highlight 这个css样式--><divclass="rel":class="{ 'rel-highlight': isHighLight }"@click="regSave">发布</div></div>

需要实现功能:当文本框输入内容时 发布按钮就会高亮。

实现思路:使用computed监听文本框的变化,当文本框的内容长度>0时,就调用isHighLight函数,动态改变按钮的class名(rel-highlight),即改变了按钮的样式 。
<div class="text"><textareaclass="text"placeholder="分享我的哔哩哔哩动态"v-model.trim="msg"></textarea></div>

v-model.trim=“msg” 给文本框的内容进行双向绑定 同时删除前后空格 (当输入空格时 发布按钮的事件并不会触发 不会高亮)

computed: {isHighLight: function () {// 判断文本框是否输入内容 有内容是true 就调用高亮函数return this.msg.length > 0;},},
上传文件:此处使用了vant

在这里插入图片描述

在这里插入图片描述

想要实现的效果就是这样的 但是当时出现了一个问题,就是我向后端发送请求之后 图片预览不出来。 (vant官方图片之所以能预览出来,是因为它自动将图片发送到vant的服务器,所以能展示出来。)
解决方法:查找vant文件上传的官方函数有:before-read=“beforeRead” 是上传前置处理,类似于钩子函数,在图片上传到vant服务器之前,将图片/视频的地址发到后端的服务器,如果上传成功,后端把拿到图片的地址和文件类型返回过来,图片/视频就可以展示出来。
:after-read=“afterRead” : 文件上传完毕后会触发 after-read 回调函数,获取到对应的 file 对象,将图片展示出来。

  <!-- 上传的图片预览 --><div class="add"><div v-for="(i, idx) in fileMe" :key="idx" class="a-showImgVideo">//当上传的文件类型为0时 就显示图片;是1时就显示视频<img class="myImg" :src="i.Mysrc" v-if="i.type == '0'" /><videoclass="myImg"width="320"height="240"v-if="i.type == '1'"autoplaymuted><source :src="i.Mysrc" type="video/mp4" /></video></div><!-- vant 上传图片/视频 --><van-uploaderv-model="fileList"multiple:before-read="beforeRead"/></div>

调用 beforeRead函数,将文件的地址和类型传送到后端服务器 成功之后拿到返回值,显示出来:

methods: {beforeRead(file) {console.log("file", file);console.log("file.type", file.type);//判断文件的类型是否是图片let type = file.type.indexOf("image") == -1 ? 1 : 0;//使用FormData 的最大优点就是可以异步上传二进制文件const forms = new FormData();forms.append("filename", file); // 增加文件的参数forms.append("type", type); // 增加类型参数//获取返回过来的图片/视频 进行展示axios({url: "/bili/dynamic/uploadPicture",method: "post",data: forms, //URLSearchParams对象用于处理URL中查询字符串,即?之后的部分。headers: {"Content-Type": "multipart/form-data",}, //php 默认要求传递请求头}).then((res) => {console.log("返回res.data", res.data);// if (res.data.data.code == "0") {// if(res.data.code == 0){console.log("上传成功", res.data.msg);let imgInfo = {Mysrc: res.data.url,type: res.data.type,};this.fileMe.push(imgInfo);//fileMe是在data里定义的 是个空的数组 存的是上传图片的地址和类型console.log("this.imgUrl", this.imgUrl);}).catch((e) => {console.log("服务器出错", e);});},
点击发布按钮之后 将文本和图片/视频上传到后端服务器
// 点击发布按钮regSave() {console.log("this.fileMe", this.fileMe);// 通过FormData将文件转成二进制数据const forms = new FormData();forms.append("uid", sessionStorage.getItem("uid")); //  uidforms.append("urlList", [this.fileMe[0].Mysrc]); // 添加 键和值forms.append("descr", this.msg); // 获取上传图片描述// forms.append("date", this.fileDate); // 获取上传图片上传时间forms.append("type", this.fileMe[0].type); // 获取上传图片类型axios({url: "/bili/dynamic/addDynamic",method: "post",data: forms, //URLSearchParams类型headers: {"Content-Type": "multipart/form-data",}, //php 默认要求传递请求头}).then((res) => {// if (res.data.status === 200) {console.log(res.data);}).catch((e) => {console.log("服务器出错了", e);});setTimeout(() => {// 发布成功 跳转到动态页面this.$router.push('/Move/Space/SpaceMy');}, 2000);},

全部代码:

<template><div class="box"><div class="top"><van-icon name="arrow-left" class="top-lef" @click="go" /><!-- 给按钮绑定一个class 如果computed返回的是true 就调用rel-highlight 这个css样式--><divclass="rel":class="{ 'rel-highlight': isHighLight }"@click="regSave">发布</div></div><van-notice-bar mode="link">新人福利,分享视频领限定头像框、个性装扮</van-notice-bar><div class="content"><div class="text"><textareaclass="text"placeholder="分享我的哔哩哔哩动态"v-model.trim="msg"></textarea></div><!-- 上传的图片预览 --><div class="add"><div v-for="(i, idx) in fileMe" :key="idx" class="a-showImgVideo"><img class="myImg" :src="i.Mysrc" v-if="i.type == '0'" /><videoclass="myImg"width="320"height="240"v-if="i.type == '1'"autoplaymuted><source :src="i.Mysrc" type="video/mp4" /></video></div><!-- 上传图片/视频 --><van-uploaderv-model="fileList"multiple:before-read="beforeRead"/></div><div class="address" v-show="isShow"><div class="address-lef"><span class="iconfont-zm icon-lujing"></span>西安市</div><div class="address-rig"><span class="iconfont-zm icon-X" @click="isShow = false"></span></div></div></div></div>
</template><script>
import axios from "axios";export default {name: "RelCenter",data() {return {// 用户输入  msgmsg: "",url: "",fileMe: [],isShow: true,fileList: [// { url: "https://img01.yzcdn.cn/vant/leaf.jpg" },// Uploader 根据文件后缀来判断是否为图片文件// 如果图片 URL 中不包含类型信息,可以添加 isImage 标记来声明],};},methods: {beforeRead(file) {console.log("file", file);console.log("file.type", file.type);//判断文件类型是不是图片let type = file.type.indexOf("image") == -1 ? 1 : 0;const forms = new FormData();forms.append("filename", file); // 获取上传图片信息forms.append("type", type); // 获取上传图片信息console.log("type shiping", type);axios({url: "/bili/dynamic/uploadPicture",method: "post",data: forms, //URLSearchParams类型headers: {"Content-Type": "multipart/form-data",}, //php 默认要求传递请求头}).then((res) => {console.log("返回res.data", res.data);// if (res.data.data.code == "0") {// if(res.data.code == 0){console.log("上传成功", res.data.msg);let imgInfo = {Mysrc: res.data.url,type: res.data.type,};this.fileMe.push(imgInfo);console.log("this.imgUrl", this.imgUrl);}).catch((e) => {console.log("服务器出错", e);});},go() {this.$router.go(-1);},// 点击发布按钮regSave() {console.log("this.fileMe", this.fileMe);// 通过FormData将文件转成二进制数据const forms = new FormData();forms.append("uid", sessionStorage.getItem("uid")); //  uidforms.append("urlList", [this.fileMe[0].Mysrc]); // 添加 键和值forms.append("descr", this.msg); // 获取上传图片描述// forms.append("date", this.fileDate); // 获取上传图片上传时间forms.append("type", this.fileMe[0].type); // 获取上传图片类型axios({url: "/bili/dynamic/addDynamic",method: "post",data: forms, //URLSearchParams类型headers: {"Content-Type": "multipart/form-data",}, //php 默认要求传递请求头}).then((res) => {// if (res.data.status === 200) {console.log(res.data);}).catch((e) => {console.log("服务器出错了", e);});setTimeout(() => {// 跳转到动态页面this.$router.push('/Move/Space/SpaceMy');}, 2000);},},computed: {isHighLight: function () {// 判断文本框是否输入内容 有内容是true 就调用高亮函数return this.msg.length > 0;},},
};
</script><style scoped>
@import url(../../assets/IconFont/Moves/font3/iconfont.css);
.box {width: 100%;
}.top {width: 100%;height: 0.44rem;line-height: 0.44rem;display: flex;justify-content: space-between;align-items: center;padding: 0 0.16rem;box-sizing: border-box;
}
.top-lef {font-size: 0.16rem;color: #000;
}
.rel {width: 0.5rem;height: 0.28rem;background-color: #e7e7e7;border-radius: 0.14rem;font-size: 0.14rem;text-align: center;line-height: 0.28rem;color: #919191;
}.content {width: 100%;
}
.text {width: 100%;height: 1.3rem;box-sizing: border-box;padding: 0.2rem 0.16rem 0;
}
textarea {width: 100%;height: 1.3rem;color: #000;font-size: 0.16rem;border: 0;outline: none;
}
.add {width: 1.14rem;height: 1.14rem;padding: 0 0.16rem;
}.van-uploader__upload {width: 1.14rem;height: 1.14rem;border: 0.01rem solid dashed;
}
.address {width: 1.05rem;height: 0.26rem;line-height: 0.26rem;margin-left: 0.12rem;color: #277ac3;border-radius: 0.13rem;margin-top: 0.7rem;position: fixed;bottom: 0.6rem;
}
.address-lef {float: left;width: 0.77rem;height: 0.26rem;text-align: center;color: #277ac3;background-color: #f4f4f4;border-top-left-radius: 0.14rem;border-bottom-left-radius: 0.14rem;box-sizing: border-box;
}
.address-rig {float: left;width: 0.26rem;height: 0.26rem;line-height: 0.26rem;text-align: center;color: #277ac3;margin-left: 0.02rem;background-color: #f4f4f4;border-top-right-radius: 0.14rem;border-bottom-right-radius: 0.14rem;
}
.icon-lujing {font-size: 0.14rem;margin-right: 0.04rem;
}
.icon-X {font-size: 0.08rem;
}
//上传成功之后图片和视频的大盒子样式
.a-showImgVideo {margin-top: 0.2rem;width: 1.2rem;height: 1.2rem;
}
.a-showImgVideo .myImg {width: 100%;height: 100%;
}
</style>
<style>
.preview-cover {position: absolute;bottom: 0;box-sizing: border-box;width: 100%;padding: 0.04rem;color: #fff;font-size: 0.12rem;text-align: center;background: rgba(0, 0, 0, 0.3);
}
.van-uploader .van-uploader__wrapper {flex-wrap: nowrap;
}/* 动态样式 */
.top .rel-highlight {background-color: #ea7a99;color: #fff;
}
</style>

这篇关于VUE哔哩哔哩移动端项目使用vant 实现发布功能(上传文件)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

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

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

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

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

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

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

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

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

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

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