Uniapp 短视频去水印解析工具开发实现

最近搞了一个有意思的小工具——短视频去水印解析器!这玩意儿可以把短视频中的水印给抹掉,还能提取视频、封面等资源。整个项目用了 Uniapp 开发,做完后体验了一下,发现还挺顺手。今天就来跟大家聊聊实现思路和代码细节~

需求分析

我们的目标是做一个简单易用的小工具,支持以下功能:

  1. 输入短视频链接,识别并解析出视频内容。
  2. 展示视频信息:视频封面、作者信息、标题等。
  3. 下载和复制功能:可以方便地复制视频链接、封面链接和标题。

代码拆解与讲解

先来看代码的大体结构,我们把主要部分放在 <template><script> 里,当然还有一些样式细节。不要着急,我们会逐段剖析,干货满满~


页面模板部分 (<template>)

首先是页面的结构,用 Vue 的模板语法来布局。这里用了 uni-notice-bar 来放一些提醒,避免用户乱用这工具(你懂的,必要的免责声明)。

<uni-notice-bar:show-icon="true":scrollable="true":single="true"text="本工具仅供学习交流实用,请勿用于商业用途。"
></uni-notice-bar>

这段代码很简单,就是一个横幅通知条,提示用户“仅供学习用途”,毕竟,咱们要做个守法的好公民。

接下来是输入框、识别按钮、展示结果的区域:

<view class="input-section card"><input v-model="inputText"  placeholder="请输入文本" class="input-box" /><view class="button-group"><button class="action-button" @tap="clearText">清空</button><button class="action-button" @tap="extractLinks">识别</button></view>
</view>
  • input:绑定 v-model="inputText",获取用户输入的链接。
  • 按钮组:两个按钮,一个清空输入框,一个开始识别。

识别链接功能 (extractLinks 方法)

代码如下:

async extractLinks() {const urlPattern = /(https?:\/\/[^\s]+)/g;const links = this.inputText.match(urlPattern);if (links && links.length > 0) {this.extractedLinks = links;this.showNoLinkMessage = false;await this.fetchVideoData(links[0]);} else {this.extractedLinks = [];this.showNoLinkMessage = true;}
}
  1. 正则匹配链接:简单地通过正则表达式来识别用户输入中的 URL。
  2. 调用视频解析函数:识别到 URL 后,就调用 fetchVideoData,尝试解析视频信息。

请求视频解析接口 (fetchVideoData 方法)

通过接口请求获取视频信息,这里用了 uni.request 方法。

async fetchVideoData(link) {const encodedURL = encodeURIComponent(link);await uni.request({url: `${VideoParserAPI}?url=${encodedURL}`,method: 'GET',success: (response) => {if (response.data.code === 200) {this.data = response.data.data;} else {this.data = null;uni.showToast({ title: response.data.msg || '解析失败', icon: 'none' });}},fail: () => {this.data = null;uni.showToast({ title: '请求出错', icon: 'none' });}});
}
  • URL编码encodeURIComponent 确保链接传递正确。
  • 请求成功:如果 code === 200,则表示解析成功,数据就放在 this.data 里,后面展示就靠这个了。
  • 请求失败:不管啥原因,直接 uni.showToast 弹个错误提示就完事了。

视频播放与信息展示

解析成功后,我们会展示作者、标题、封面等信息,顺便整了个播放按钮。

<view class="card" v-if="data"><view class="author"><image :src="data.author.avatar" class="avatar"></image><text class="author-name">{{ data.author.name }}</text></view><text class="title">{{ data.title }}</text><image :src="data.cover_url" class="cover"></image><button class="play-button" @tap="playVideo">播放视频</button>
</view>
  • v-if="data":只有当 data 有内容时才显示。
  • 播放视频:点击按钮后 playVideo 方法会显示 <video> 标签,开始播放视频。
playVideo() {this.showVideo = true;
}

下载和复制功能

提供了几个按钮,可以让用户复制视频的标题、链接等信息。代码如下:

copyTitle() {if (this.data && this.data.title) {uni.setClipboardData({data: this.data.title,success: () => {uni.showToast({ title: '标题已复制', icon: 'success' });},fail: () => {uni.showToast({ title: '复制失败', icon: 'none' });}});}
}

其他按钮(如复制视频链接、复制封面链接)逻辑类似,就不赘述了。

样式与美化

页面的样式主要集中在 <style> 标签内,针对不同组件进行样式定义,比如 cardinput-boxbutton-group 等等。

.container {display: flex;flex-direction: column;align-items: center;padding: 20rpx;background-color: #f5f5f5;
}
.input-box {width: 100%;height: 60rpx;padding: 10rpx;border: 1px solid #ccc;border-radius: 10rpx;margin-bottom: 10rpx;
}
.action-button {width: 45%;height: 60rpx;background-color: #007aff;color: #fff;border-radius: 10rpx;
}

样式设计保持简洁,让用户可以愉快地使用,整个页面风格清新、简洁。

下面是效果展示:

在这里插入图片描述


总结

整个过程还是蛮顺畅的,主要是借助了 Uniapp 和现成的视频解析 API 来实现短视频去水印解析的核心功能。当然,代码中还是有一些细节需要注意,比如正则表达式的使用、接口请求的错误处理等。整个工具界面友好,操作简单,相信大家用起来会感觉不错!

代码其实也没啥复杂的地方,简单实用才是硬道理。希望大家喜欢这个工具,如果你有更好的优化建议,欢迎一起交流~

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

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

相关文章

HTML【详解】input 标签

input 标签主要用于接收用户的输入&#xff0c;随 type 属性值的不同&#xff0c;变换其具体功能。 通用属性 属性属性值功能name字符串定义输入字段的名称&#xff0c;在表单提交时&#xff0c;服务器通过该名称来获取对应的值disabled布尔值禁用输入框&#xff0c;使其无法被…

什么是MVC?什么是SpringMVC?什么是三层架构?

文章目录 应用分层什么是MVC?什么是 SpringMVC&#xff1f;三层架构三层架构和MVC的关系 应用分层 在讲解什么是MVC之前&#xff0c;先来理解一下什么是应用分层。 应用分层是一种软件开发设计思想&#xff0c;将应用程序划分成N个层次&#xff0c;每个层次都分别负责自己…

【深度学习】深度学习和强化学习算法——深度 Q 网络DQN

深度 Q 网络&#xff08;Deep Q-Network, DQN&#xff09; 详解 什么是DQNDQN 的背景DQN 训练流程 2 DQN 的核心思想2.1 经验回放&#xff08;Experience Replay&#xff09;2.2 目标网络&#xff08;Target Network&#xff09;2.3 ε-贪心策略&#xff08;ε-Greedy Policy&a…

CSS flex布局 列表单个元素点击 本行下插入详情独占一行

技术栈&#xff1a;Vue2 javaScript 简介 在实际开发过程中有遇到一个场景&#xff1a;一个list&#xff0c;每行个数固定&#xff0c;点击单个元素后&#xff0c;在当前行与下一行之间插入一行元素详情&#xff0c;便于更直观的查看到对应的数据详情。 这种情形&#xff0c…

Deepseek本地部署

一&#xff0c;Deepseek本地部署方式 有UI且简单&#xff1a;LM Studio、Text Generation WebUI。 高效率但无UI&#xff1a;Ollama、LLama.cpp、Tabby。 二&#xff0c;通过Ollama本地部署Deepseek 1&#xff0c;什么是Ollama Ollama是一个开源的 LLM&#xff08;大型语言…

Django 创建表时 “__str__ ”方法的使用

在 Django 模型中&#xff0c;__str__ 方法是一个 Python 特殊方法&#xff08;也称为“魔术方法”&#xff09;&#xff0c;用于定义对象的字符串表示形式。它的作用是控制当对象被转换为字符串时&#xff0c;应该返回什么样的内容。 示例&#xff1a; 我在初学ModelForm时尝…

最新智能优化算法: 中华穿山甲优化( Chinese Pangolin Optimizer ,CPO)算法求解23个经典函数测试集,MATLAB代码

中华穿山甲优化&#xff08; Chinese Pangolin Optimizer &#xff0c;CPO&#xff09;算法由GUO Zhiqing 等人提出&#xff0c;该算法的灵感来自中华穿山甲独特的狩猎行为&#xff0c;包括引诱和捕食行为。 算法流程如下&#xff1a; 1. 开始 设置算法参数和最大迭代次数&a…

【云安全】云原生- K8S etcd 未授权访问

什么是etcd&#xff1f; etcd 是一个开源的分布式键值存储系统&#xff0c;主要用于存储和管理配置信息、状态数据以及服务发现信息。它采用 Raft 共识算法&#xff0c;确保数据的一致性和高可用性&#xff0c;能够在多个节点上运行&#xff0c;保证在部分节点故障时仍能继续提…

解锁建造者模式:Java 编程中的对象构建秘籍

系列文章目录 后续补充~~~~ 文章目录 一、引言二、建造者模式原理剖析2.1 定义与概念2.2 模式结构与角色2.2.1 产品&#xff08;Product&#xff09;2.2.2 建造者&#xff08;Builder&#xff09;2.2.3 具体建造者&#xff08;ConcreteBuilder&#xff09;2.2.4 指挥者&#xf…

ChatGPT行业热门应用提示词案例-AI绘画类

AI 绘画指令是一段用于指导 AI 绘画工具&#xff08;如 DALLE、Midjourney 等&#xff09;生成特定图像的文本描述。它通常包含场景、主体、风格、色彩、氛围等关键信息&#xff0c;帮助 AI 理解创作者的意图&#xff0c;从而生成符合要求的绘画作品。 ChatGPT 拥有海量的知识…

JUC并发—4.wait和notify以及Atomic原理

大纲 1.wait()与notify()实现一个简易的内存队列 2.wait()与notify()的底层原理 3.分布式存储系统NameNode机制介绍 4.分布式存储系统的edits log机制介绍 5.分布式存储系统的NameNode实现 6.分布式存储系统的创建目录功能的实现 7.edits log的全局txid机制和双缓冲机制…

ubuntu20.04声音设置

step1&#xff1a;打开pavucontrol&#xff0c;设置Configuration和Output Devices&#xff0c; 注意需要有HDMI / DisplayPort (plugged in)这个图标。如果没有&#xff0c;就先选择Configuration -> Digital Stereo (HDMI 7) Output (unplugged) (unvailable)&#xff0c;…

【网络安全 | 漏洞挖掘】价值3133美元的Google IDOR

未经许可,不得转载。 文章目录 正文正文 目标URL:REDACTED.google.com。 为了深入了解其功能,我查阅了 developer.google.com 上的相关文档,并开始进行测试。 在测试过程中,我发现了一个 XSS 漏洞,但它触发的域名是经过正确沙盒化的 *.googleusercontent.com,这符合 …

企业级API集成方案:基于阿里云函数计算调用DeepSeek全解析

解决方案链接&#xff1a;https://www.aliyun.com/solution/tech-solution/deepseek-r1-for-platforms?utm_contentg_1000401616 何为DeepSeek R1 DeepSeek R1模型有诸多技术优势。高效架构设计使其能更高效提取特征&#xff0c;减少冗余计算&#xff0c;提升数据处理速度、…

qt-C++笔记之QGraphicsScene和 QGraphicsView中setScene、通过scene得到view、通过view得scene

qt-C++笔记之QGraphicsScene和 QGraphicsView中setScene、通过scene得到view、通过view得scene code review! 文章目录 qt-C++笔记之QGraphicsScene和 QGraphicsView中setScene、通过scene得到view、通过view得scene1.`setScene` 方法2.通过 `scene` 获取它的视图 (`views()`)…

深度学习(1)-简单神经网络示例

我们来看一个神经网络的具体实例&#xff1a;使用Python的Keras库来学习手写数字分类。在这个例子中&#xff0c;我们要解决的问题是&#xff0c;将手写数字的灰度图像&#xff08;28像素28像素&#xff09;划分到10个类别中&#xff08;从0到9&#xff09;​。我们将使用MNIST…

【AI】Docker中快速部署Ollama并安装DeepSeek-R1模型: 一步步指南

【AI】Docker中快速部署Ollama并安装DeepSeek-R1模型: 一步步指南 一、前言 为了确保在 Docker 环境中顺利安装并高效运行 Ollama 以及 DeepSeek 离线模型&#xff0c;本文将详细介绍整个过程&#xff0c;涵盖从基础安装到优化配置等各个方面。通过对关键参数和配置的深入理解…

将OpenWrt部署在x86服务器上

正文共&#xff1a;1234 字 40 图&#xff0c;预估阅读时间&#xff1a;2 分钟 如果你问ChatGPT有哪些开源的SD-WAN方案&#xff0c;他会这样答复你&#xff1a; 我们看到&#xff0c;OpenWrt也属于比较知名的开源SD-WAN解决方案。当然&#xff0c;在很久之前&#xff0c;我就发…

【区块链】零知识证明基础概念详解

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 零知识证明基础概念详解引言1. 零知识证明的定义与特性1.1 基本定义1.2 三个核心…

Elasticsearch:将 Ollama 与推理 API 结合使用

作者&#xff1a;来自 Elastic Jeffrey Rengifo Ollama API 与 OpenAI API 兼容&#xff0c;因此将 Ollama 与 Elasticsearch 集成非常容易。 在本文中&#xff0c;我们将学习如何使用 Ollama 将本地模型连接到 Elasticsearch 推理模型&#xff0c;然后使用 Playground 向文档提…