【uni-app】详细总结uni-app基础知识和如何配置项目,运行到模拟器和小程序端,附案例和图(建议收藏)
创始人
2024-02-27 05:29:42
0

1- uni-app 简介


1.1 介绍

uni-app 是一个使用 Vue.js 开发所有前端应用的框架。 开发者编写一套代码,可发布到 iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉/淘宝)、快应用等多个平台。

在这里插入图片描述

详细的 uni-app 官方文档,请翻阅 https://uniapp.dcloud.net.cn/

1.2 总结

  1. 由dcloud公司开发的 多端融合框架,1次开发,多端运行;
  2. 竞品:apiCloud ,appCan,Codova
  3. 技术架构:Vue语法+小程序的api
  4. 多端混合开发Hybrid
  • App端
    • nvue(原生view)
    • native.js(js原生沟通的桥梁)
    • weex
    • 内置ios/安卓的模块使用
  • H5端(h5专用api)
  • 各种小程序(微信为主)

2- 工具


2.1 前言

准备工具:

  • HbuilderX(开发与编译工具)
  • 微信开发工具(微信小程序预览测试)
  • 安卓模拟器/真机(运行app)

2.2 HbuilderX

uni-app 官方推荐使用 HBuilderX 来开发 uni-app 类型的项目。

可以根据自己的喜好,选择喜欢的编辑器!

2.2.1 下载安装 HbuilderX
  1. 访问 HBuilderX 的官网首页 https://www.dcloud.io/hbuilderx.html
  2. 点击首页的DOWNLOAD按钮
  3. 选择下载正式版-> App 开发版
  4. 将下载的zip包进行解压缩
  5. 将解压之后的文件夹,存放到纯英文的目录中(且不能包含括号等特殊字符)
  6. 双击HBuilderX.exe即可启动 HBuilderX

2.3 微信开发工具

这个我们学微信小程序的时候,已经安装过了,此处不再赘述…

不太明白的小伙伴,可以看这篇博客 【微信小程序】小程序使用详细教程(建议收藏)

2.4 安卓模拟器/真机

针对这个,小媛下载了 木木模拟器,小伙伴可以安装自己喜欢的模拟器。

木木模拟器网址https://mumu.163.com/

安装步骤此处不再赘述…

3- 新建uni-app项目


3.1 新建项目

  1. 文件 -> 新建 -> 项目

在这里插入图片描述

  1. 填写项目基本信息

在这里插入图片描述

  1. 项目创建成功

在这里插入图片描述

3.2 界面介绍

3.2.1 目录结构

一个 uni-app 项目,默认包含如下目录及文件:

┌─components            uni-app组件目录
│  └─comp-a.vue         可复用的a组件
├─pages                 业务页面文件存放的目录
│  ├─index
│  │  └─index.vue       index页面
│  └─list
│     └─list.vue        list页面
├─static                存放应用引用静态资源(如图片、视频等)的目录,注意:静态资源只能存放于此
├─main.js               Vue初始化入口文件
├─App.vue               应用配置,用来配置小程序的全局样式、生命周期函数等
├─manifest.json         配置应用名称、appid、logo、版本等打包信息
└─pages.json            配置页面路径、页面窗口样式、tabBar、navigationBar 等页面类信息

在这里插入图片描述

3.2.2 页面介绍

在这里插入图片描述

4- 运行uni-app项目


4.1 运行到微信开发者

把项目运行到微信开发者工具:

  1. 填写自己的微信小程序的 AppID

在这里插入图片描述

  1. 在 HBuilderX 中,配置“微信开发者工具”的安装路径

在这里插入图片描述

  1. 在微信开发者工具中,通过设置 -> 安全设置面板,开启“微信开发者工具”的服务端口

在这里插入图片描述

  1. 在 HBuilderX 中,点击菜单栏中的 运行 -> 运行到小程序模拟器 -> 微信开发者工具,将当前 uni-app 项目编译之后,自动运行到微信开发者工具中,从而方便查看项目效果与调试:

在这里插入图片描述

  1. 初次运行成功之后的项目效果:

在这里插入图片描述

4.2 运行H5

  1. 在 HBuilderX 中,点击菜单栏中的 运行 -> 运行到内置浏览器,将当前 uni-app 项目编译之后,自动运行到内置中,从而方便查看项目效果与调试:

在这里插入图片描述

  1. 初次运行成功之后的项目效果:

在这里插入图片描述

4.3 运行到木木模拟器

不同的模拟器对应的端口号,我们需要配置:

  • 夜神模拟器端口号:62001
  • 海马模拟器端口号:26944
  • 逍遥模拟器端口号:21503
  • MuMu模拟器端口号:7555
  • 天天模拟器端口号:6555
  1. 打开模拟器或者手机

在这里插入图片描述

  1. 打开配置模拟器的端口,需要点击 运行-->运行到手机或模拟器--> Android模拟器端口设置

在这里插入图片描述

  1. 配置模拟器的端口,此处填写木木模拟器的端口号 7555;

在这里插入图片描述

  1. 运行到模拟器

在这里插入图片描述

  1. 点击运行

在这里插入图片描述

注意:

  1. 先打开木木模拟器
  2. hHuilder可能需要下载对应的插件,运行到安卓模拟器,有视图差别,运行需要时间
  1. 成功运行项目

在这里插入图片描述

5- uni-app 生命周期


5.0 生命周期

详细内容可取uni-app 官网查看

在这里插入图片描述

5.1 vue的生命周期

具体内容可看博客:【Vue】Vue2生命周期详解

在这里插入图片描述

5.2 小程序的生命周期

5.2.1 简介

小程序中,生命周期主要分成了三部分:

  • 应用的生命周期

小程序的生命周期函数是在app.js里面调用的,通过App(Object)函数用来注册一个小程序,指定其小程序的生命周期回调

  • 页面的生命周期

页面生命周期函数就是当你每进入/切换到一个新的页面的时候,就会调用的生命周期函数,同样通过App(Object)函数用来注册一个页面

  • 组件的生命周期

组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发,通过Component(Object)进行注册组件

5.2.2 生命周期
  • 应用的生命周期
生命周期说明
onLaunch小程序初始化完成时触发,全局只触发一次
onShow小程序启动,或从后台进入前台显示时触发
onHide小程序从前台进入后台时触发
onError小程序发生脚本错误或 API 调用报错时触发
onPageNotFound小程序要打开的页面不存在时触发
onUnhandledRejection()小程序有未处理的 Promise 拒绝时触发
onThemeChange系统切换主题时触发
  • 页面的生命周期
生命周期说明作用
onLoad生命周期回调—监听页面加载发送请求获取数据
onShow生命周期回调—监听页面显示请求数据
onReady生命周期回调—监听页面初次渲染完成获取页面元素(少用)
onHide生命周期回调—监听页面隐藏终止任务,如定时器或者播放音乐
onUnload生命周期回调—监听页面卸载终止任务
  • 组件的生命周期
生命周期说明
created生命周期回调—监听页面加载
attached生命周期回调—监听页面加载
ready生命周期回调—监听页面初次渲染完成
moved生命周期回调—监听页面隐藏
detached生命周期回调—监听页面卸载
error生命周期回调—监听页面卸载

5.3 小程序的全局方法

具体内容可看博客:【小程序】微信小程序常用api的使用,附案例(建议收藏)

在这里插入图片描述

6- 页面和路由


6.1 路由组件

navigator 导航

  • url 跳转页面的地址
  • open-type 打开类型
    • navigate 跳转、
    • redirect重定向(当前页面不留历史记录)
    • navigateBack 返回、
    • relaunch 重启、
    • switchTab 跳转底部栏
6.1.1 案例
  • index.vue
		

6.2 路由传参

传递参数

  • url 里拼接 count=5&title=来自index

接收参数

6.2.1 案例
  • life.vue
		
  • options.vue
		onLoad(option) {//console.log("ccc", option);this.count = option.count;uni.setNavigationBarTitle({title: option.title})},

在这里插入图片描述

6.3 路由API

可以在官方网址查看API:https://uniapp.dcloud.net.cn/api/router.html#

在这里插入图片描述

uni.navigateTo({url}) 跳转
uni.redirectTo({url}) 重定向
uni.navigateBack() 返回
uni.switchTab() 底部栏切换
uni.reLaunch() 重启

6.3.1 案例
  • life.vue
		
methods: {goOptions() {uni.navigateTo({// 跳转并传参url: "/pages/options/options?count=1000&title=来自js跳转"})},goIndex() {// 重定向uni.redirectTo({url: '/pages/index/index'})},}

在这里插入图片描述

6.4 获取当前页面getApp()

6.4.1介绍

getApp() 函数用于获取当前应用实例,一般用于获取globalData 。

实例

const app = getApp()
console.log(app.globalData)

注意:

  • 不要在定义于App()内的函数中,或调用App前调用 getApp() ,可以通过this.$scope获取对应的app实例
  • 通过getApp()获取实例之后,不要私自调用生命周期函数。
  • 当在首页nvue中使用getApp()不一定可以获取真正的App对象。对此提供了const app = getApp({allowDefault: true})用来获取原始的App对象,可以用来在首页对globalData等初始化
6.4.2 案例
  1. App.vue 定义
globalData:{num:100}
  1. 要使用的页面获取app
var app = getApp()


  1. 获取globalData的值
onShow(){this.num = app.globalData.num
​}
  1. 更新globalData
addNum(){
app.globalData.num++;
this.num = app.globalData.num
​}

在这里插入图片描述

6.5 获得页面栈getCurrentPages

6.5.1介绍

getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。

注意: getCurrentPages()仅用于展示页面栈的情况,请勿修改页面栈,以免造成页面状态错误。

每个页面实例的方法属性列表:

方法描述平台说明
page.$getAppWebview()获取当前页面的webview对象实例App
page.route获取当前页面的路由

注意:

- navigateTo, redirectTo 只能打开非 tabBar 页面。

  • switchTab 只能打开 tabBar 页面。
  • reLaunch 可以打开任意页面
  • 页面底部的tabBar由页面决定,即只要是定义为 tabBar 的页面,底部都有 tabBar
  • 不能在 App.vue 里面进行页面跳转。
6.5.2 案例
  • 获取当前的页面栈,是一个数组(1-5)
var page = getCurrentPages
uni.navigateBack({delta:page.length})
//page[page.length-1]获取当前页面的信息不要去修改
  • code
    在这里插入图片描述

6.6 路由配置 tabBar

  • pages.json 配置底部栏
"tabBar": {"color": "#777777","selectedColor": "#ff3300","list": [{"pagePath": "pages/index/index","iconPath": "static/home.png","selectedIconPath": "static/home-active.png","text": "首页"},{"pagePath": "pages/options/options","iconPath": "static/sort.png","selectedIconPath": "static/sort-acitve.png","text": "选项"}]},
  • code

在这里插入图片描述
在这里插入图片描述

7- 条件编译


7.1 简介

条件编译是用特殊的注释作为标记,在编译时根据这些特殊的注释,将注释里面的代码编译到不同平台。

写法:以#ifdef#ifndef%PLATFORM%开头,以 #endif 结尾。

解释:

  • #ifdef:if defined 仅在某平台存在
  • #ifndef:if not defined 除了某平台均存在
  • %PLATFORM%:平台名称

在这里插入图片描述
在这里插入图片描述

具体内容可查看uni-app 官网https://uniapp.dcloud.net.cn/tutorial/platform.html

7.2 模板条件编译

  1. 在 hHuilder 写以下代码:
		条件H5:下载App 获取优惠券App 优惠券0.5元微信小程序福利专享
  1. 在不同的端,我们可以看到不同的内容

在这里插入图片描述
在这里插入图片描述

7.3 CSS条件编译

  1. 在 hHuilder 写以下代码:

我要变成不同的颜色

  1. 在不同的端,我们可以看到不同的内容

在这里插入图片描述

在这里插入图片描述

7.4 js条件编译

  1. 在 hHuilder 写以下代码:


  1. 在不同的端,我们可以看到不同的内容

在这里插入图片描述

7.5 跨平台条件配置

7.5.1 页面配置
  1. 新建一个页面在 condition文件夹 里,命名为 weixin.vue ,在pages.json 写以下代码:

在这里插入图片描述

//  #ifdef MP-WEIXIN || APP{"path": "pages/condition/weixin","style": {"navigationBarTitleText": "小程序专有页面"}},// #endif
  1. condition.vue 里,写以下代码:
	
  1. 在不同的端,我们可以看到不同的内容

在这里插入图片描述
在这里插入图片描述

7.5.2 导航栏配置
  1. 不同端的导航栏配置不同的内容

在这里插入图片描述

  1. pages.json 写以下代码:
        {"path" : "pages/condition/condition","style" :                                                                                    {"navigationBarTitleText": "条件编译","enablePullDownRefresh": false,"app-plus": {"titleNView": false //隐藏导航栏},"h5": {"titleNView": {"titleText": "H5:条件编译"}}}}

8- 总结


今天先分享到这里了~~~

往期传送门


【小程序】微信小程序常用api的使用,附案例(建议收藏)

【微信小程序】小程序使用详细教程(建议收藏)

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【Ctfer训练计划】——(三... 作者名:Demo不是emo  主页面链接:主页传送门 创作初心ÿ...