uni-app一课一得

目录

一、uni-app框架介绍及环境配置 

二、 HX的特点:

三、安装HBuilder X 及使用

三,示例


一、uni-app框架介绍及环境配置 

 (1)发展历程:uni-app是一个使用vue.js开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、H5以及微信、百度、支付宝等各种小程序,它极大的简化了应用程序的开发过程,大大提高了开发效率。

(2)开发环境的配置

HBuilder简称HX 。HX是轻如编辑器、强如IDE的合体版本。https://www.dcloud.io/hbuilderx.html

二、 HX的特点:

轻巧。仅十几MB的绿色发行包(不含插件)。
运行速度快。不管是启动速度、大文档打开速度,还是编码提示,均实现了极速响应。vue开发强化。HX对vue做了大量优化投入,开发体验远超其他开发工具。
小程序支持。国外开发工具没有对中国的小程序开发优化,HX可新建uni-app或小程序、快应用等项目,为国人提供更高效的工具。
markdown利器。HX是唯一新建文件默认类型是markdown的编辑器,也是对md支持最图强的编辑器,HX为md强化了众多功能,可在“菜单”→“帮助”→“markdown 语法示例”中查看,快速掌握md及HX的强化技巧。
界面清爽简洁。HX的界面比其他工具更为简洁,绿柔主题经过科学的脑疲劳测试,是最适合人眼长期观看的主题界面。
高效极客工具。更强大的多光标、智能双击,让字处理的效率大幅提升。
更强的JSON支持。现代JS开发中大量JSON结构的写法,HX提供了比其他工具更高效的操作。
HX的扩展性:
·HX支持Java插件、node.js插件,并兼容了大部分vscode的插件及代码块。
支持通过外部命令方便地调用各种命令行功能,并设置快捷键。
支持快捷键导入。其他工具(如vscode或sublime)的快捷键,在“菜单”→“快捷键”方案中可以切换。

三、安装HBuilder X 及使用

1、进入官网下载

 2、各种插件的安装

3、项目的创建

(在创建项目的时应注意根目录的选择,避免与其他项目重名)

4、uni-app的结构 

1 pages目录:各种页面的存放

2 static目录:静态资源的存放

3  App.vue文件:本项目的根组件

4 main.js文件:项目的入口文件,在项目加载时,先加载main.js文件

5 pages.json文件:配置页面的路由、导航条、顶部标题按钮搜索框、选项卡等页面类信息

6 uni.scss文件:配置一些样式

三,示例

页面跳转

//在起始页面跳转到test.vue页面并传递参数
uni.navigateTo({
	url: 'test?id=1&name=uniapp'
});

// 在test.vue页面接受参数
export default {
	onLoad: function (option) { //option为object类型,会序列化上个页面传递的参数
		console.log(option.id); //打印出上个页面传递的参数。
		console.log(option.name); //打印出上个页面传递的参数。
	}
}

// 在起始页面跳转到test.vue页面,并监听test.vue发送过来的事件数据
uni.navigateTo({
  url: 'pages/test?id=1',
  events: {
    // 为指定事件添加一个监听器,获取被打开页面传送到当前页面的数据
    acceptDataFromOpenedPage: function(data) {
      console.log(data)
    },
    someEvent: function(data) {
      console.log(data)
    }
    ...
  },
  success: function(res) {
    // 通过eventChannel向被打开页面传送数据
    res.eventChannel.emit('acceptDataFromOpenerPage', { data: 'data from starter page' })
  }
})

// 在test.vue页面,向起始页通过事件传递数据
onLoad: function(option) {
  const eventChannel = this.getOpenerEventChannel();
  eventChannel.emit('acceptDataFromOpenedPage', {data: 'data from test page'});
  eventChannel.emit('someEvent', {data: 'data from test page for someEvent'});
  // 监听acceptDataFromOpenerPage事件,获取上一页面通过eventChannel传送到当前页面的数据
  eventChannel.on('acceptDataFromOpenerPage', function(data) {
    console.log(data)
  })
}

url有长度限制,太长的字符串会传递失败,可改用窗体通信全局变量,另外参数中出现空格等特殊字符时需要对参数进行编码,如下为使用encodeURIComponent对参数进行编码的示例。

<navigator :url="'/pages/test/test?item='+ encodeURIComponent(JSON.stringify(item))"></navigator>

// 在test.vue页面接受参数
onLoad: function (option) {
	const item = JSON.parse(decodeURIComponent(option.item));
}

注意:

  • 页面跳转路径有层级限制,不能无限制跳转新页面
  • 跳转到 tabBar 页面只能使用 switchTab 跳转
  • 路由API的目标页面必须是在pages.json里注册的vue页面。如果想打开web url,在App平台可以使用 plus.runtime.openURL或web-view组件;H5平台使用 window.open;小程序平台使用web-view组件(url需在小程序的联网白名单中)。在hello uni-app中有个组件ulink.vue已对多端进行封装

总结:学习uni-app可以让开发者掌握跨平台开发技能,提高开发效率和代码复用率,同时也可以提升Vue.js和小程序开发技能,是一项非常有价值的技能

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值