【前端技术】uni-app 01:快速开始

news2025/1/11 5:41:39

开个新坑,学习一下 uni-app,之后也想 uni-app 来做些事,虽然我主业是后端,但 uni-app 其作为一个高效生产力工具,个人认为非常有必要学习一下~

目录

1 uni-app 介绍

1.1 uni-app 由来

1.2 为什么选择 uni-app

1.3 HBuilderX

2 创建第一个 uni-app 项目

2.1 使用 HBuilderX 创建项目

2.2 目录结构

2.3 运行 uni-app

① 浏览器运行

② 微信开发者工具里运行


1 uni-app 介绍

官网地址:https://uniapp.dcloud.net.cn/

uni-app 是基于 Vue.js 开发的跨平台应用开发框架,可将一套代码同时运行在 iOSAndroidH5小程序等多个平台,开发者只需编写一次代码即可轻松实现跨平台应用的开发。

简单来说,uni-app 类似于三头六臂的哪吒,一个框架干了 appweb 小程序的活,简直是不给其他框架活路呀~

1.1 uni-app 由来

DCloud 于2012年开始研发小程序技术,加入W3C和HTML5中国产业联盟,推出了HBuilder开发工具。

2015年,DCloud 正式商用了自己的小程序,产品名为“流应用”,并将技术标准捐献给 HTML5 中国产业联盟,并推进各家流量巨头接入该标准,开展小程序业务。 360手机助手率先接入,在其3.4版本实现应用的秒开运行。

2015年9月,DCloud 推进微信团队开展小程序业务,微信团队经过分析,于2016年初决定上线小程序业务,但其没有接入联盟标准,而是订制了自己的标准。

DCloud持续在业内普及小程序理念,推进各大流量巨头,包括手机厂商,陆续上线类似小程序/快应用等业务。部分公司接入了联盟标准,但更多公司因利益纷争严重,标准难以统一

于是 DCloud 决定开发一个免费开源的框架,这就是 uni-app 的由来,uni,读 you ni,是统一的意思。

DCloud 作者大大初心:为开发者提供免费、高效的开发工具,让天下没有难做的应用。改进应用形态,让用户更方便地获取数字服务。

1.2 为什么选择 uni-app

个人觉得有以下几点:

  • 跨平台开发:uniapp 可以实现一次开发、多平台发布(包括 iOS、Android、H5、小程序等),不需要分别针对不同平台进行开发。

  • 提高开发效率:uniapp 使用 vue.js 作为开发框架,提供了丰富的组件和API,并且开发过程中可以实时预览效果,使得开发效率更高。

  • 性能优秀:uniapp采用原生渲染技术,可以提供更好的性能表现,并且可以针对不同平台进行优化。

  • 生态丰富:uniapp拥有庞大的社区和生态圈,提供了丰富的开发资源和解决方案,可以帮助开发者快速解决问题。

官方推荐理由 👇

1.3 HBuilderX

HBuilderX 正是 DCloud 公司推出的一款非常实用的前端集成开发环境,那平时我们开发 uni-app 项目时就可以使用 HBuilderX 来开发。

简单来说,HBuilderX 采用了通用的前端开发技术,可以跨平台使用,支持 Windows、Mac OS、Linux 等操作系统。

📌 下载 HBuilderX 开发者工具

官方地址:https://www.dcloud.io/hbuilderx.html

可按电脑系统类别(window 或 mac)下载对应的压缩包,建议还是选择正式版,稳定一些~

📌 打开 HBuilderX

解压该压缩包后,内容如下 👇

此时,直接点击 HBuilderX.exe 文件即可打开 HBuilderX 工具!第一次打开时,我们可以选择主题快捷键方案,我选择的是雅蓝主题Intellij Idea/Webstorm 快捷键方案(因为 Idea 用惯了),仅供参考~

 进来后是这个页面,HBuilderX 的自夸 👇

总体来说,和 vscode 类似,还是比较容易上手的!

由于是压缩包形式,因此一开始不存在快捷方式,此时我们可以右键 HBuilderX.exe ,选择创建快捷方式,然后将快捷方式移到桌面就行了。

2 创建第一个 uni-app 项目

2.1 使用 HBuilderX 创建项目

依次点击工具栏里的文件 -> 新建 -> 项目(快捷键Ctrl+N)👇

如图所示,选择 uni-app 类型后,输入项目名称、选择模板、vue 版本(因为 uniapp 基于 vue 开发,因此需要选择 vue 版本)后,点击创建,即可成功创建。

如果是学习阶段,那么用不到 uniCloud gitCode 代码托管平台,因此不用勾选。

uni-app 自带的模板有默认的空项目模板、Hello uni-app 官方组件和 API 示例,还有一个重要模板是 uni ui 项目模板,日常开发推荐使用该模板,已内置大量常用组件。

2.2 目录结构

以下是创建成功后的项目内容 👇

可以看到该结构和 vue 项目类似,这是因为 uniapp 就是基于 vue 框架,而且小程序也是借鉴了vue ,如果对 vue 不是很熟悉的话可以先了解一下:初识 Vue.js

一个完整的 uni-app 工程,默认包含如下目录及文件:

┌─uniCloud              云空间目录,阿里云为uniCloud-aliyun,腾讯云为uniCloud-tcb(详见uniCloud)
│─components            符合vue组件规范的uni-app组件目录
│  └─comp-a.vue         可复用的a组件
├─utssdk                存放uts文件
├─pages                 业务页面文件存放的目录
│  ├─index
│  │  └─index.vue       index页面
│  └─list
│     └─list.vue        list页面
├─static                存放应用引用的本地静态资源(如图片、视频等)的目录,注意:静态资源只能存放于此
├─uni_modules           存放[uni_module](/uni_modules)。
├─platforms             存放各平台专用页面的目录
├─nativeplugins         App原生语言插件 
├─nativeResources       App端原生资源目录
│  ├─android            Android原生资源目录 
|  └─ios                iOS原生资源目录 
├─hybrid                App端存放本地html文件的目录,
├─wxcomponents          存放小程序组件的目录,
├─unpackage             非工程代码,一般存放运行或发行的编译结果
├─AndroidManifest.xml   Android原生应用清单文件
├─Info.plist            iOS原生应用配置文件
├─main.js               Vue初始化入口文件
├─App.vue               应用配置,用来配置App全局样式以及监听 应用生命周期
├─manifest.json         配置应用名称、appid、logo、版本等打包信息
├─pages.json            配置页面路由、导航条、选项卡等页面类信息
└─uni.scss              这里是uni-app内置的常用样式变量

官方详细解释:https://uniapp.dcloud.net.cn/collocation/pages.html

2.3 运行 uni-app

HBuilderX 神器提供多平台预览功能,接下来我以浏览器微信小程序为例。

① 浏览器运行

依次点击工具栏的运行 -> 运行到浏览器 -> 选择浏览器,即可体验 uni-app 的 web 版,那么我们选择它的内置浏览器!第一次使用内置浏览器会提示:安装插件,我们点击确定,安装即可。

此时我们就可以在内置浏览器上预览我们的项目了,这相当于个调试器,可以帮助我们进行开发和解决 bug

② 微信开发者工具里运行

📌 前提:安装小程序开发者工具

如果已经安装了微信小程序开发者工具,可直接跳过该部分内容。

官方地址:https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html

我们根据电脑系统,然后选择这个稳定版进行下载,它是安装包,因此只需要双击安装包,选择安装路径,不停的点下一步即可,然后记住这个微信小程序开发者工具路径HBuilderX 中需要用到 👇

📌 开启微信开发者工具服务端口

然后我们需要开启微信开发者工具服务端口,依次打开微信开发者工具 -> 设置 -> 安全设置,将服务端口开启。

📌 运行到微信小程序

依次点击工具栏的运行 -> 运行到小程序模拟器 -> 微信开发者工具,选择微信开发工具的路径,即可在微信开发者工具里面体验uni-app。

可以看到在微信开发工具中,该项目启动成功!!

该过程中,我们需要在微信开发者工具里点击下信任并运行。支付宝,抖音等小程序都是一样的流程。除了运行项目,还有个发布,这会在之后进行记录。

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

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

相关文章

Win7 64位 VS2015及MinGW环境编译矢量库agg-2.5和cairo-1.14.6

书接上文,昨天装了MinGW,主要原因之一是要用到MSYS,所以顺手把FFMPEG又编译了一遍。 回到主题,其实我是想编译矢量库,因为最近要学习一些计算几何算法,所以找个方便的2D画图库就很重要。 说白了其实是懒得…

我把GPT 的学习轨迹可视化了竟和人类十分类似 |ACL2023

回想一下我们小时候是如何习得一门语言的?一般而言,在人类婴儿出生第一年内,最开始婴儿只能模仿式的说出一些“音素”,说出一些最简单与基本的单词或句子,而伴随着成长,在大约一岁到三岁的阶段,…

windows进程结构体

了解进程线程的概念后,我们就来看看windows里面的进程长什么样子的。进程本质上就是一个结构体。在Linux里面也称之为进程描述符。当操作系统创建一个进程的时候,它会填充一个结构体,往这个结构体里写入数据,这个结构体就用于管理…

Queue,List,Deque联系

如图所示,可以得出LinkedList既可以是双向链表也可以是双端队列,Deque接口继承了Queue接口 Queue add(E):boolean 在队尾添加元素,添加成功返回true,如果队列已满无法添加则抛出异常。offer(E):boolean 在队尾添加元素&#xff0…

linux mail -s发送邮件异常解决

异常: Error initializing NSS: Unknown error -8015. "/root/dead.letter" 11/301 . . . message not sent. 出现此问题,大概率是和证书相关。如果没有安装证书,请先安装: 1,下载 yum -y install mailx …

Python采集某xsp内容, m3u8视频内容下载

前言 大家早好、午好、晚好吖 ❤ ~欢迎光临本文章 环境使用: Python 3.8 Pycharm 专业版 模块使用: import requests >>> pip install requests import re 正则表达式 解析数据 import json 基本步骤去实现 一. 数据来源分析 通过开发者工具进行抓包分析, 分…

轻松构建交互式应用程序:探索Gradio Components模块的神奇世界!

❤️觉得内容不错的话,欢迎点赞收藏加关注😊😊😊,后续会继续输入更多优质内容❤️ 👉有问题欢迎大家加关注私戳或者评论(包括但不限于NLP算法相关,linux学习相关,读研读博…

抽头延迟线信道模型

本专栏包含信息论与编码的核心知识,按知识点组织,可作为教学或学习的参考。markdown版本已归档至【Github仓库:https://github.com/timerring/information-theory 】或者公众号【AIShareLab】回复 信息论 获取。 文章目录 时变多径信道的信道…

突破技术边界,开创“粽“享未来

突破技术边界,开创“粽“享未来 端午节的由来端午节的习俗端午祈福 博主 默语带您 Go to New World. ✍ 个人主页—— 默语 的博客👦🏻 《java 面试题大全》 🍩惟余辈才疏学浅,临摹之作或有不妥之处,还请读…

南京阿里云代理商:阿里云服务器的可扩展性和弹性如何?是否支持按需付费?

南京阿里云代理商:阿里云服务器的可扩展性和弹性如何?是否支持按需付费?   一、阿里云服务器的可扩展性   阿里云作为业界知名的云服务提供商,其服务器具有极强的可扩展性。可扩展性主要体现在以下几方面:   1. …

行为型模式--状态模式

目录 举例 状态模式 定义 结构 代码实现 优缺点 优点: 缺点: 使用场景 举例 【例】通过按钮来控制一个电梯的状态,一个电梯有开门状态,关门状态,停止状态,运行状态。每一 种状态改变,都…

Xdebug的安装及使用

Xdebug的安装及使用 前言一、Xdebug如何配置二、PHPstrom配置三、Xdebug的使用1.面板功能解释2.调试功能详解 四、Xdebug原理 前言 软件调试是泛指重现软件缺陷问题,定位和 查找问题根源,最终解决问题的过程,编写的程序不可能一直不出错,所以调试很重要调试通常有如…

西安阿里云代理商:阿里云服务器的可扩展性和弹性如何?是否支持按需付费?

西安阿里云代理商:阿里云服务器的可扩展性和弹性如何?是否支持按需付费?   一、阿里云服务器的可扩展性   阿里云作为业界知名的云服务提供商,其服务器具有极强的可扩展性。可扩展性主要体现在以下几方面:   1. …

小米note3刷机-从miui12刷回miui9

小米note3刷机-从miui12刷回miui9 文章目录 小米note3刷机-从miui12刷回miui9解除BL锁进入开发者模式遇到的问题解决BootLoader无法连接电脑的问题 导包 3月份原本想买一部小米6回来刷机,结果发现小米6的二手价格有一点点high。然后就选了一个 大平版 小米note3 但是直到昨天…

SpringBoot 如何使用 Logback 进行日志记录

SpringBoot 如何使用 Logback 进行日志记录 在开发 Web 应用程序时,日志记录是非常重要的一部分。日志可以帮助我们跟踪应用程序的运行情况,并帮助我们快速地排查问题。在 SpringBoot 中,我们可以使用 Logback 进行日志记录。Logback 是一款…

F407/103MAP文件

认识MAP文件 MDK编译工程,会生成一些中间文件(如.o、.axf、.map 等),最终生成hex文件,以便下载到MCU上面执行。这些文件分为 11 个类型,其中4种文件比较重要。 比如: 本文主要讲解map文件。 map…

第四章 死锁

目录 一、死锁的概念 1.1 什么是死锁 1.2 死锁、饥饿、死循环的区别 1.2.1 死锁 1.2.2 饥饿 1.2.3 死循环 1.2.4 三者间的异同 1.3 死锁产生的必要条件 1.3.1 互斥条件 1.3.2 不剥夺条件 1.3.3 请求和保持条件 1.3.4 循环等待条件 1.4 什么时候会发生死锁 1.5 …

深入理解Java中的synchronized

文章目录 前言正文一、多线程操作同一数据时的问题二、问题分析三、synchronized 解决问题四、synchronized 是怎么解决问题的五、Java1.6时的优化5.1 自旋锁5.2 自适应锁5.3 锁消除5.4 锁粗化5.5 偏向锁(单线程高效场景)5.2 轻量级锁(多线程…

MySQL数据表查询

😇作者介绍:一个有梦想、有理想、有目标的,且渴望能够学有所成的追梦人。 🎆学习格言:不读书的人,思想就会停止。——狄德罗 ⛪️个人主页:进入博主主页 🗼专栏系列:进入MySQL知识专…

IO、存储、文件系统的简单介绍

目录 一.什么是IO 第一类:存储器IO 第二类:设备IO 二.存储 三:文件系统 总结 一.什么是IO I(input):放入数据 O(output):取出数据 所以我们平时说的IO,实际上就是放入数据和存储数据的意思 在这里,我们一般将IO又分为两大类 第一类:存储器IO 这类IO主要针对的是计算机中…