首页 > 网名 正文
「qq音乐克隆歌曲名字」qq空间音乐克隆器…

时间:2023-06-11 作者:佚名

点击上方 "程序员小乐"关注, 星标或置顶一起成长

每天凌晨00点00分, 第一时间与你相约

每日英文

Don't put your happiness in the hands of someone else. If you really want to be happy, you have to find this happiness within yourself.

不要把自己的快乐寄托在别人身上,真正的快乐,必须来源于自己。

每日掏心话

每一次的容忍,都是一次爱的消耗。请珍稀我的每一次容忍与退让,因为那是我对你爱的信用额度,但再高的额度也终有透支的一天。

来自:xiangzhihong | 责编:乐乐

链接:

程序员小乐(ID:study_tech)第 786 次推文 图片来自网络

往日回顾:大公司为什么都有API网关?聊聊API网关的作用

00 前言

虽然 B/S 是目前开发的主流,但是 C/S 仍然有很大的市场需求。受限于浏览器的沙盒限制,网页应用无法满足某些场景下的使用需求,而桌面应用可以读写本地文件、调用更多系统资源,再加上 Web 开发的低成本、高效率的优势,这种跨平台方式越来越受到开发者的喜爱。

Electron 是一个基于 Chromium 和 Node.js,使用 HTML、CSS 和 JavaScript 来构建跨平台应用的跨平台开发框架,兼容 Mac、Windows 和 Linux。目前,Electron 已经创建了包括 VScode 和 Atom 在内的大量应用。

01 正文

环境搭建

创建 Electron 跨平台应用之前,需要先安装一些常用的工具,如 Node、vue 和 Electron 等。

安装Node

进入 Node 官网下载页 ,然后下载对应的版本即可,下载时建议下载稳定版本。如果安装 Node 使用 Homebrew 方式,建议安装时将 npm 仓库镜像改为淘宝镜像,如下所示。

npm config set registry
或者
npm install -g cnpm --registry=

安装/升级 vue-cli

先执行以下命令,确认下本地安装的 vue-cli 版本。

vue -V

如果没有安装或者不是最新版,可以执行以下命令安装/升级。

npm install @vue/cli -g

安装 Electron

使用如下命令安装 Electron 插件。

npm install -g electron
或者
cnpm install -g electron

为了验证是否安装成功,可以使用如下的命令。

electron --version

创建运行项目

Electron 官方提供了一个简单的项目,可以执行以下命令将项目克隆到本地。

git clone

然后在项目中执行如下命令即可启动项目。

cd electron-quick-start
npm install
npm start

启动后项目的效果如下图。

除此之外,我们可以使用 vue-cli 脚手架工具来创建项目。

vue init simulatedgreg/electron-vue

然后根据下面的提示一步步选中选项即可创建项目,如下所示。

然后,使用 npm install 命令安装项目所需要的依赖包,安装完成之后,可以使用 npm run dev 或 npm run build 命令运行 electron-vue 模版应用程序,运行效果如下图所示。

Electron 源码目录

Electron 的源代码主要依据 Chromium 的拆分约定被拆成了许多部分。为了更好地理解源代码,您可能需要了解一下 Chromium 的多进程架构。

Electron 源码目录结构和含义具体如下:

Electron
├──atom - Electron 的源代码
| ├── app - 系统入口代码
| ├── browser - 包含了主窗口、UI 和其他所有与主进程有关的东西,它会告诉渲染进程如何管理页面
| | ├── lib - 主进程初始化代码中 JavaScript 部分的代码
| | ├── ui - 不同平台上 UI 部分的实现
| | | ├── cocoa - Cocoa 部分的源代码
| | | ├── gtk - GTK+ 部分的源代码
| | | └── win - Windows GUI 部分的源代码
| | ├── default_app - 在没有指定 app 的情况下 Electron 启动时默认显示的页面
| | ├── API - 主进程 API 的实现
| | | └── lib - API 实现中 Javascript 部分的代码
| | ├── net - 网络相关的代码
| | ├── mac - 与 Mac 有关的 Objective-C 代码
| | └── resources - 图标,平台相关的文件等
| ├── renderer - 运行在渲染进程中的代码
| | ├── lib - 渲染进程初始化代码中 JavaScript 部分的代码
| | └── api - 渲染进程 API 的实现
| | └── lib - API 实现中 Javascript 部分的代码
| └── common - 同时被主进程和渲染进程用到的代码,包括了一些用来将 node 的事件循环
| | 整合到 Chromium 的事件循环中时用到的工具函数和代码
| ├── lib - 同时被主进程和渲染进程使用到的 Javascript 初始化代码
| └── api - 同时被主进程和渲染进程使用到的 API 的实现以及 Electron 内置模块的基础设施
| └── lib - API 实现中 Javascript 部分的代码
├── chromium_src - 从 Chromium 项目中拷贝来的代码
├── docs - 英语版本的文档
├── docs-translations - 各种语言版本的文档翻译
├── spec - 自动化测试
├── a - Electron 的构建规则
└── common.gypi - 为诸如 `node` 和 `breakpad` 等其他组件准备的编译设置和构建规则

平时开发时,需要重点关注的就是 src、 和 a 目录。除此之外,其他需要注意的目录如下:

  • script - 用于诸如构建、打包、测试等开发用途的脚本

  • tools - 在 gyp 文件中用到的工具脚本,但与 script 目录不同, 该目录中的脚本不应该被用户直接调用

  • vendor - 第三方依赖项的源代码,为了防止人们将它与 Chromium 源码中的同名目录相混淆, 在这里我们不使用 third_party 作为目录名

  • node_modules - 在构建中用到的第三方 node 模块

  • out - ninja 的临时输出目录

  • dist - 由脚本 scri 创建的临时发布目录

  • external_binaries - 下载的不支持通过 gyp 构建的预编译第三方框架

应用工程目录

使用 electron-vue 模版创建的 Electron 工程结构如下图。

和前端工程的项目结构类似,Electron 项目的目录结构如下所示:

  • electron-vue:Electron模版配置。

  • build:文件夹,用来存放项目构建脚本。

  • config:中存放项目的一些基本配置信息,最常用的就是端口转发。

  • node_modules:这个目录存放的是项目的所有依赖,即 npm install 命令下载下来的文件。

  • src:这个目录下存放项目的源码,即开发者写的代码放在这里。

  • static:用来存放静态资源。

  • index.html:则是项目的首页、入口页,也是整个项目唯一的HTML页面。

  • :中定义了项目的所有依赖,包括开发时依赖和发布时依赖。

对于开发者来说, 90% 的工作都是在 src 中完成,src 中的文件目录如下。

Electron 应用程序分成三个基础模块:主进程、进程间通信和渲染进程。

1、主进程

Electron 运行 的 main 脚本(background.js)的进程被称为主进程。在主进程中运行的脚本通过创建web页面来展示用户界面。一个 Electron 应用总是有且只有一个主进程。

2、渲染进程

由于 Electron 使用了 Chromium 来展示 Web 页面,所以 Chromium 的多进程架构也被使用到。每个 Electron 中的 Web 页面运行在它自己的渲染进程中。在普通的浏览器中,Web 页面通常在一个沙盒环境中运行,不被允许去接触原生的资源。然而 Electron 允许用户在 Node.js 的 API 支持下可以在页面中和操作系统进行一些底层交互。

3、主进程与渲染进程通信

主进程使用 BrowserWindow 实例创建页面。每个 BrowserWindow 实例都在自己的渲染进程里运行页面。当一个 BrowserWindow 实例被销毁后,相应的渲染进程也会被终止。主进程管理所有的 Web 页面和它们对应的渲染进程。每个渲染进程都是独立的,它只关心它所运行的 Web 页面。

src 目录结构

在 Electron 目录中,src 会包包含 main 和 renderer 两个目录。

main 目录

main 目录会包含 index.js 和 index.dev.js 两个文件。

  • index.js:应用程序的主文件,electron 也从这里启动的,它也被用作 webpack 产品构建的入口文件,所有的 main 进程工作都应该从这里开始。

  • index.dev.js:此文件专门用于开发阶段,因为它会安装 electron-debug 和 vue-devtools。一般不需要修改此文件,但它可以扩展开发的需求。

渲染进程

renderer 是渲染进程目录,平时项目开发源码的存放目录,包含 assets、components、router、store、A 和 main.js。

assets:assets 下的文件如(js、css)都会在 dist 文件夹下面的项目目录分别合并到一个文件里面去。components:此文件用于存放应用开发的组件,可以是自定义的组件。router:如果你了解 vue-router,那么 Electron 项目的路由的使用方式和 vue-router 的使用方式类似。modules:electron-vue 利用 vuex 的模块结构创建多个数据存储,并保存在 src/renderer/store/modules 中。

综合示例

1、网易云音乐

electron-vue-cloud-music是一款使用Electron+Vue+Ant Design Vue技术开发跨平台桌面应用。下载链接:。具有如下特点:

  • 拖拽播放

  • 桌面歌词

  • mini模式

  • 自定义托盘右键菜单

  • 任务栏缩略图,歌曲操作

  • 音频可视化

  • 自动/手动检查更新

  • Nedb数据库持久化

  • 自定义安装路径,安装界面美化

  • 浏览器中启动客户端

  • Travis CL,AppVeyor自动构建

  • 换肤,下载,本地歌曲匹配,网络变化桌面通知,分享歌曲/歌单/MV/视频等到QQ空间

  • 登录,私人Fm,歌单,专辑,歌手,排行榜,MV,视频,评论,搜索,用户,动态,粉丝,关注,云盘,收藏...

  • 心动模式,歌词微调,下一首播放,追加播放,单曲循环,随机播放,列表循环

  • 路由导向,局部刷新,首页栏目调整并持久化...

以下是部分运行效果:


2、qq音乐播放器

qq音乐播放器基于 electron-vue 开发的音乐播放器,界面模仿QQ音乐,使用的技术栈electron-vue+vue+vuex+vue-router+element- UI。可以使用如下的方式来运行项目。

git clone

cd electron-vue-music

npm install

# 运行开发模式
npm run dev

# 打包安装文件
npm run build

部分运行效果如下图。

欢迎在留言区留下你的观点,一起讨论提高。如果今天的文章让你有新的启发,学习能力的提升上有新的认识,欢迎转发分享给更多人。

猜你还想看

阿里、腾讯、百度、华为、京东最新面试题汇集

Java 多态的实现机制,看了都说好!

中央政治局会议:疫情防控工作取得阶段性成效,但拐点尚未到来

SpringBoot实现过滤器、拦截器与切片

关注订阅号「程序员小乐」,收看更多精彩内容
嘿,你在看吗?

本文信息为网友自行发布旨在分享与大家阅读学习,文中的观点和立场与本站无关,如对文中内容有异议请联系处理。

本文链接:https://www.paituo.cc/wangming/1066352.html

  • 相关阅读

    “qq音乐克隆歌曲名字“qq音乐克隆器手机版

    qq音乐克隆歌曲名字,qq音乐克隆器手机版,qq空间音乐克隆在线版相关介绍,哈喽,黑粉们! 欢迎来到黑马公社啊! 在今天, 黑马要推荐几款“自带会员”的软件, 以此替代你在用的那些常规应用。 黑马保证,你们用过之后, 就会彻底爱上它们。 众所周知, QQ是目前用户量上亿的聊天

    QQ音乐外部歌曲名字,qq音乐怎么改歌曲名字?

    QQ音乐外部歌曲名字,qq音乐怎么改歌曲名字,qq斗地主音乐歌曲名字相关介绍,对于广大车主来说,音乐是必不可少的娱乐方式,边开车边听音乐也是一件十分惬意的事情。不过,要想获得最佳的听觉感受,除了汽车自身过硬的配置外,还离不开汽车厂商和音乐平台的协作。据CNMO了解,QQ音乐近日

    [qq音乐克隆歌曲名字]qq音乐在线克隆?

    qq音乐克隆歌曲名字,qq音乐在线克隆,qq空间音乐克隆在线版相关介绍,QQ 音乐用户在哪里?举起你们的双手,让我看到! 网易云 QQ 并不知道在哪里的用户,请上车 ୧(๑•̀◡•́๑)૭ 前些日子三家音乐巨头版权大战,让网易云音乐死忠粉不得不含泪转移阵地。 可惜 QQ

    ‘qq音乐克隆歌曲名字’qq空间音乐克隆在线版…

    qq音乐克隆歌曲名字,qq空间音乐克隆在线版,qq空间音乐克隆器手机版相关介绍,如今,用手机听歌已经是非常普遍的现象,手机几乎可以和大多数人同行半天以上。 既然有这么多人在用手机听音乐,自然也会有很多朋友也在考虑如何改善听歌时的使用体验。购买音频设备或许是一个比较好的方法,但就需

    QQ音乐外部歌曲名字、qq音乐怎么改歌曲名字?

    QQ音乐外部歌曲名字,qq音乐怎么改歌曲名字,qq斗地主音乐歌曲名字相关介绍,大家好,这里只是普通而富有的解放路桥本康娜,我想成为你的大猫~ 要说国内能叫名字的音乐品牌,梦想音乐绝对可以说是一件事。在大猫的认知中,梦想音乐中有太多著名的说唱歌手。Gai、Baba、Bridge、

    qq炫舞跳舞不显示名字、炫舞跳舞时如何不显示人?

    qq炫舞跳舞不显示名字,炫舞跳舞时如何不显示人,炫舞跳舞不显示翅膀相关介绍,南都讯 记者杨丽云 手机网络游戏产品的防沉迷机制实施情况如何?近日,中国消费者协会公布50款手机网络游戏产品(以下简称“手游”)的消费体验报告。结果显示,50款游戏产品均未见账号永久注销或删除功能。超

    ‘qq启个什么名字帅’启的儿子叫什么名字

    qq启个什么名字帅,启的儿子叫什么名字,qq启什么名字好听相关介绍,每次我一个人走夜路都好害怕,天这么黑,我这么美,真怕别人看不见啊。 今天小编分享一些搞笑网名男生,希望能博你一笑。 劳资一上线,全球都停电 上课的铃声比忐忑还更忐忑 鲸鱼洗澡 人不猥琐枉少年 香蕉你个

    ‘qq炫舞手游彩色名字’qq炫舞手游名字变色…

    qq炫舞手游彩色名字,qq炫舞手游名字变色,qq炫舞手游彩色名字代码怎么弄相关介绍,6399:QQ炫舞手游4月10日停机更新内容一览 为了给玩家带来更好的游戏体验,服务器将于2018年4月10日(周二)上午4:00至7:00进停机更新,届时欢迎各位舞者再次回到炫舞大陆!QQ炫舞手游4