热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

uniapp框架超详细新手入门

什么是uni-app?(介绍)uni-app是一个使用Vue.js开发跨平台应用的前端框架。开发者通过编写Vue.js代码,uni-app将其编译到iOS、Andr
什么是uni-app?(介绍)

uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架。
开发者通过编写 Vue.js 代码,uni-app 将其编译到iOS、Android、微信小程序等多个平台,保证其正确运行并达到优秀体验。

uni-app 继承自 Vue.js,提供了完整的 Vue.js 开发体验。
uni-app 组件规范和扩展api与微信小程序基本相同。

有一定 Vue.js 和微信小程序开发经验的开发者可快速上手 uni-app ,开发出兼容多端的应用。

uni-app提供了条件编译优化,可以优雅的为某平台写个性化代码、调用专有能力而不影响其他平台。

uni-app打包到App时仍然使用了5+引擎,5+的所有能力都可以在uni-app中可以使用。在App端运行性能和微信小程序基本相同。

对于技术人员而言:不用学那么多的平台开发技术、研究那么多前端框架,学会基于vue的uni-app就够了。
对于公司而言:更低成本,覆盖更多用户,uni-app是高效利器
 

uni-app的优点


  1. uni-app是一套可以适用多端的开源框架,一套代码可以同时生成ios,Android,H5,微信小程序,支付宝小程序,百度小程序等。
  2. uni-app对前端开发人员比较友好,学习成本比较低,首先uni-app是基于vue.js的。其次封装的组件和微信小程序的组件一模一样,所以对于现在的主流前端人员来说学习几乎为零,如果你作为一个前端,没有接触过vue和微信小程序的话那建议你多去加加油。
  3. uni-app使用HBX进行开发,HBX对于vue语法等支持可以说是比较完备了。使用HBX进行开发可以说是速度杠杠的。开发速度比较快
  4. uni-app拓展能力强,封装了H5+,支持nvue,也支持原生Android,ios开发。可以将原有的移动应用和H5应用改成uni-app应用。
  5. uni-app是DCloud出品的,属于国产,对于国产我们当然要支持一下
     

uni-app的缺点


  1. uni-app问世的时间还比较短,有很多地方还不是完善,坑很多,建议不喜欢爬坑的朋友那就少用uni-app。
  2. 对于使用中的一些bug及问题,官方回应的不是很及时。
     

uni-app的功能框架浏览图

在这里插入图片描述
 

工具安装

首先开发者需先下载安装 HBuilderX
在这里插入图片描述
接着在HBuilderX 点击工具栏里的文件 -->新建 -->项目:
在这里插入图片描述
创建uni-app
在这里插入图片描述

项目结构介绍

在这里插入图片描述
 
目录结构基本和小程序的目录结构相似,只是多了个基础组件的文件夹;
uni-app有自己的插件库,直接点击安装即可,而且,它也支持npm包管理,点击 工具 >> 插件安装 即可配置
在这里插入图片描述
 

uni-app开发规范

为了实现微信小程序、原生App的跨端兼容,综合考虑编译速度、运行性能等因素,uni-app 约定了如下开发规范:

页面文件遵循 Vue 单文件组件 (SFC) 规范
每个 .vue 文件包含三种类型的顶级语言块:
1.最多包含一个模板模块
2.最多包含一个脚本模块
3.可以包含一个或多个样式模块,标签可以有scoped或者module属性,不同封装模式的多个style可以在同一个组件中混合使用,如可包含css、sass、less等多种封装模式。
Tips:允许添加可选的自定义块,支持导入自定义块,需要注意的是 src 导入遵循和 webpack 模块请求相同的路径解析规则,这意味着相对路径需要以 ./开始

组件标签靠近微信小程序规范,所以有微信开发经验的话将会飞速上手uni-app,没有经验也不要怕,即使不会微信小程序也会快速上手。
注意:不能使用标准HTML标签,也不能用js对dom进行操作

接口能力(JS API)靠近微信小程序规范,不过前缀 wx 需要替换为 uni

数据绑定及事件处理靠近 Vue.js 规范,同时补充了App及页面的生命周期,为兼容多端运行,建议使用flex布局进行开发
 

uni-app的样式与布局

注意:请删除 app.vue 中的全局样式:view{display:flex;} 在需要flex的时候使用flex即可。

尺寸单位

uni-app框架目前仅支持长度单位 px 和 %。与传统 web 页面不同,px 是相对于基准宽度的单位,已经适配了移动端屏幕,其原理类似于 rem。
PS:uni-app 的基准宽度为 750px。
开发者只需按照设计稿确定框架样式中的 px 值即可。设计稿 1px 与框架样式 1px 转换公式如下:设计稿 1px / 设计稿基准宽度 = 框架样式1px / 750px
换言之,页面元素宽度在uni-app中的宽度计算公式:750px * 元素在设计稿中的宽度 / 设计稿基准宽度

举例说明:

若设计稿宽度为 640px,元素 A 在设计稿上的宽度为 100px,那么元素 A 在uni-app里面的宽度应该设为:750 * 100 / 640,结果为:117px。

若设计稿宽度为 375px,元素 B 在设计稿上的宽度为 200px,那么元素 B 在uni-app里面的宽度应该设为:750 * 200 / 375,结果为:400px。

样式导入

使用@import语句可以导入外联样式表,@import后跟需要导入的外联样式表的相对路径,用;表示语句结束。

示例代码:
<style>&#64;import "../../common/uni.css";.uni-card {box-shadow: none;}
</style>

内联样式

框架组件上支持使用 style、class 属性来控制组件的样式。

style&#xff1a;静态的样式统一写到 class 中。style 接收动态的样式&#xff0c;在运行时会进行解析&#xff0c;请尽量避免将静态的样式写进 style 中&#xff0c;以免影响渲染速度。

<view style&#61;"color:{{color}};" />

class&#xff1a;用于指定样式规则&#xff0c;其属性值是样式规则中类选择器名(样式类名)的集合&#xff0c;样式类名不需要带上.&#xff0c;样式类名之间用空格分隔。

<view class&#61;"normal_view" />

选择器

目前支持的选择器有&#xff1a;
.class .intro 选择所有拥有 class&#61;“intro” 的组件
#id #firstname 选择拥有 id&#61;“firstname” 的组件
element view 选择所有 view 组件
element, element view, checkbox 选择所有文档的 view 组件和所有的 checkbox 组件
::after view::after 在 view 组件后边插入内容&#xff0c;仅微信小程序和5&#43;App生效
::before view::before 在 view 组件前边插入内容&#xff0c;仅微信小程序和5&#43;App生效

全局样式与局部样式

定义在 App.vue 中的样式为全局样式&#xff0c;作用于每一个页面。在 pages 目录下 的 vue 文件中定义的样式为局部样式&#xff0c;只作用在对应的页面&#xff0c;并会覆盖 App.vue 中相同的选择器。
注意&#xff1a; App.vue 中通过 &#64;import 语句可以导入外联样式&#xff0c;一样作用于每一个页面。

Flex布局

为支持跨平台&#xff0c;框架建议使用Flex布局&#xff0c;关于Flex布局可以参考外部文档A Complete Guide to Flexbox等。
 

注意

1.请删除 app.vue 中的全局样式&#xff1a;view{display:flex;} 在需要flex的时候使用flex即可。
2.App.vue 中通过 &#64;import 语句可以导入外联样式&#xff0c;一样作用于每一个页面。
 

总结

本篇文章介绍了 uin-app 框架的介绍, 安装, 创建, 和基本的样式与布局,如有任何疑问请移步官网


推荐阅读
  • uniapp 框架简介和生命周期
    介绍:uni-app使用vue的语法小程序的标签和API。也就是和这些语法同样作用的框架.生命周期,分为应用生命周期和页面生命周期,和小程序的基本一致.流程开发规范为了实现多 ... [详细]
  • 团队作业第二次—项目选题报告(追光的人)
    所属课程软件工程1916作业要求团队作业第二次—项目选题报告团队名称追光的人作业目标组员提出选题,大家挑选出可行性最高的进行分析,制作选题报告和选题PPT目录队员贡献分比例选题报告 ... [详细]
  • 微信小程序使用uni-app实现首页搜索框导航栏功能详解
    这篇文章主要介绍了微信小程序使用uni-app实现首页搜索框导航栏功能,uni-app 是一个使用 Vue.js (opens new window)开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序 ... [详细]
  • 基于Vue.js的uniapp前端框架结合.net core开发跨平台project
    一、由来最近由于业务需要要开发一套公益的APP项目,因此结合所给出的需求最终采用uni-app这种跨平台前端框架以及.netcore快速搭建我们的项目, ... [详细]
  • wordpress 不显示特色图片_微慕WordPress小程序专业版v2.0_信息流_搜索板块_行业资讯...
    不经意间,微慕专业版发布已经过去一年了,微慕开源版的推出也有两年半了。2017年5月间,我花了2天时间,用WordPress ... [详细]
  • 【Windows】实现微信双开或多开的方法及步骤详解
    本文介绍了在Windows系统下实现微信双开或多开的方法,通过安装微信电脑版、复制微信程序启动路径、修改文本文件为bat文件等步骤,实现同时登录两个或多个微信的效果。相比于使用虚拟机的方法,本方法更简单易行,适用于任何电脑,并且不会消耗过多系统资源。详细步骤和原理解释请参考本文内容。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • Google Play推出全新的应用内评价API,帮助开发者获取更多优质用户反馈。用户每天在Google Play上发表数百万条评论,这有助于开发者了解用户喜好和改进需求。开发者可以选择在适当的时间请求用户撰写评论,以获得全面而有用的反馈。全新应用内评价功能让用户无需返回应用详情页面即可发表评论,提升用户体验。 ... [详细]
  • Vue.Js_Vue之vue.js声明式渲染
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Vue之vue.js声明式渲染相关的知识,希望对你有一定的参考价值。ht ... [详细]
  • hello,我又要细说uniapp了附件上传,图片上传,视频上传应该是目前手机比较常见的功能,但是对于上传还是有一些需要注 ... [详细]
  • 微信公众号酒酒酒搜索“微信H5分享外部链接,缩略图不显示”查看原文前言:最近做了一款推广茶的APP软件,展厅、产品需要分享功能࿱ ... [详细]
  • 1.支付能力a.开发步骤:1.登录开发中心,选择相应的小程序,进入该小程序详情页2.在小程序详情开发管理页面的功能列表中,点击右上角添加功能按钮,添加【小程序支付】功能,提交进入审 ... [详细]
  • uniAPP 网络连接实现轮播图
    uni.request(O ... [详细]
  • 摘要:通过介绍数据中心不同时期动力环境监控系统的建设和发展,结合数据机房的维护对象、动力环境监控系统的软件组成和工作原理,探讨云计算数据中心动力环境监控系统的配套需求和“集中管理、集中监控集 ... [详细]
  • uni-app入门uni,从这个单词的意思,就能看的出来,Dcoud社区的野心这个试图统治整个前端界的技术,到底有没有那么好呢࿱ ... [详细]
author-avatar
林亚培_724
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有