目录
一、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和小程序开发技能,是一项非常有价值的技能