uni-app学习日记2

1.H5开发webapp
解析:webapp本质上是个html页面,需要基于浏览器运行。如果想要操作手机内部的软件或者硬件,需要浏览器的支持。

2.选择h5开发web APP还是原生APP
解析:
[1]应用是否需要使用某些设备的特殊功能,比如摄像头,摄像头闪光灯或者重力加速器。
[2]开发预算是多少。
[3]应用是否一定需要网络。
[4]应用的目标硬件设备是所有的移动设备还是仅仅只是一部分而已。
[5]已经熟悉的开发语言。
[6]这个应用对于性能要求是否苛刻。
[7]如何靠这个应用赢利。

3.globalStyle
解析:用于设置应用的状态栏、导航条、标题、窗口背景色等。
[1]navigationBarTextStyle:导航栏标题颜色及状态栏前景颜色,仅支持black/white
[2]navigationBarBackgroundColor:导航栏背景颜色[同状态栏背景色]
[3]backgroundColor:窗口的背景色

4.package.json
解析:通过在package.json文件中增加uni-app扩展节点,可实现自定义条件编译平台[比如,钉钉小程序、微信服务号等平台]。package.json文件中不允许出现注释,否则扩展配置无效。

5.vue.config.js
解析:vue.config.js是一个可选的配置文件,如果项目的根目录中存在这个文件,那么它会被自动加载,一般用于配置webpack等编译选项。

6.uni.scss
解析:uni.scss文件的用途是为了方便整体控制应用的风格。比如按钮颜色、边框风格,uni.scss文件里预置了一批scss变量预置。如果你是插件开发者,建议使用scss预处理,并在插件代码中直接使用这些变量[无需import这个文件]。

7.App.vue应用生命周期
解析:App.vue是主组件,所有页面都是在App.vue下进行切换的,是页面入口文件。uni-app支持如下应用生命周期函数:
[1]onLaunch:当uni-app初始化完成时触发(全局只触发一次)
[2]onShow:当uni-app启动,或从后台进入前台显示
[3]onHide:当uni-app从前台进入后台
[4]onError:当uni-app报错时触发
[5]onUniNViewMessage:对nvue页面发送的数据进行监听,可参考nvue向vue通讯
说明:应用生命周期仅可在App.vue中监听,在其它页面监听无效。App.vue不能写模板。

8.App.vue globalData
解析:小程序有globalData机制,这套机制在uni-app里也可以使用,全端通用。
[1]js中操作globalData的方式如下:getApp().globalData.text=‘test’。
[2]在应用onLaunch时,getApp对象还未获取,暂时可以使用this.$scope.globalData获取globalData。

9.App.vue全局样式
解析:在App.vue中,可以一些定义全局通用样式,例如需要加一个通用的背景色,首屏页面渲染的动画等都可以写在App.vue中。

10.App main.js
解析:main.js是入口文件,主要作用是初始化vue实例并使用需要的插件。首先引入了Vue库和App.vue,创建了一个vue实例,并且挂载vue实例。

11.框架接口:页面通讯
解析:
[1]uni.$emit(eventName,OBJECT):触发全局的自定事件。附加参数都会传给监听器回调。
[2]uni.$on(eventName,callback):监听全局的自定义事件。事件可以由uni.$emit触发,回调函数会接收所有传入事件触发函数的额外参数。
[3]uni.$once(eventName,callback):监听全局的自定义事件。事件可以由uni.$emit触发,但是只触发一次,在第一次触发之后移除监听器。
[4]uni.$off([eventName,callback]):移除全局自定义事件监听器。

12.框架接口:页面
解析:
[1]getApp():函数用于获取当前应用实例,一般用于获取globalData。
[2]getCurrentPages():函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面。
[3]$getAppWebview():uni-app在getCurrentPages()获得的页面里内置了一个方法$getAppWebview()可以得到当前webview的对象实例,从而实现对webview更强大的控制。

13.组件生命周期
解析:uni-app组件支持的生命周期,与vue标准组件的生命周期相同。这里没有页面级的onLoad等生命周期:
[1]beforeCreate:在实例初始化之后被调用。
[2]created:在实例创建完成后被立即调用。
[3]beforeMount:在挂载开始之前被调用。
[4]mounted:挂载到实例上去之后调用。
[5]beforeUpdate:数据更新时调用,发生在虚拟DOM打补丁之前。
[6]updated:由于数据更改导致的虚拟DOM重新渲染和打补丁,在这之后会调用该钩子。
[7]beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。
[8]destroyed:Vue实例销毁后调用。调用后,Vue实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

14.页面生命周期
解析:uni-app支持如下页面生命周期函数:
[1]onLoad:监听页面加载,其参数为上个页面传递的数据,参数类型为Object[用于页面传参]
[2]onShow:监听页面显示。页面每次出现在屏幕上都触发,包括从下级页面点返回露出当前页面
[3]onReady:监听页面初次渲染完成。注意如果渲染速度快,会在页面进入动画完成前触发
[4]onHide:监听页面隐藏
[5]onUnload:监听页面卸载
[6]onResize:监听窗口尺寸变化
[7]onPullDownRefresh:监听用户下拉动作,一般用于下拉刷新
[8]onReachBottom:页面滚动到底部的事件[不是scroll-view滚到底],常用于下拉下一页数据
[9]onTabItemTap:点击tab时触发,参数为Object
[10]onShareAppMessage:用户点击右上角分享
[11]onPageScroll:监听页面滚动,参数为Object
[12]onNavigationBarButtonTap:监听原生标题栏按钮点击事件,参数为Object
[13]onBackPress:监听页面返回
[14]onNavigationBarSearchInputChanged:监听原生标题栏搜索输入框输入内容变化事件
[15]onNavigationBarSearchInputConfirmed:监听原生标题栏搜索输入框搜索事件,用户点击软键盘上的“搜索”按钮时触发
[16]onNavigationBarSearchInputClicked:监听原生标题栏搜索输入框点击事件

15.uni-app配置
解析:
[1]pages.json
[2]manifest.json
[3]package.json
[4]vue-config.js
[5]uni.scss
[6]App.vue
[7]main.js

16.uni-app框架接口
[1]日志打印
[2]定时器
[3]生命周期
[4]页面
[5]页面通讯

17.uni-app中原生组件清单
解析:
[1]map
[2]video
[3]camera[仅微信小程序、百度小程序支持]
[4]canvas[仅在微信小程序、百度小程序表现为原生组件]
[5]input[仅在微信小程序、百度小程序、支付宝小程序、头条小程序中且input置焦时表现为原生组件]
[6]textarea[仅在微信小程序、百度小程序、头条小程序表现为原生组件]
[7]live-player[仅微信小程序、百度小程序支持,App端直接使用video组件可同时实现拉流]
[8]live-pusher[仅微信小程序、百度小程序、app-nvue支持,app-vue使用plus.video.LivePusher可实现推流]
[9]cover-view
[10]cover-image

18.web-view
解析:web-view是一个web浏览器组件,可以用来承载网页的容器,会自动铺满整个页面。

19.Worker wx.createWorker(string scriptPath)
解析:创建一个Worker线程。目前限制最多只能创建一个Worker,创建下一个Worker前请先调用Worker.terminate。

20.devServer
解析:
[1]https:启用https协议
[2]disableHostCheck:禁用Host检查

21.optimization
解析:
[1]prefetch:资源预取
[2]preload:资源预加载
[3]treeShaking:摇树优化,根据项目需求,动态打包框架所需的组件及API,保持框架代码最精简化

22.uni-ui
解析:uni-ui是DCloud提供的一个跨端ui库,它是基于vue组件的、flex布局的、无dom的跨全端ui框架。uni-ui不包括基础组件,它是基础组件的补充。如下所示:
[1]Badge:数字角标
[2]Calendar:日历
[3]Card:卡片
[4]Collapse:折叠面板
[5]CountDown:倒计时
[6]Drawer:抽屉
[7]Fab:悬浮按钮
[8]Fav:收藏按钮
[9]GoodsNav:底部购物导航
[10]Grid:宫格
[11]Icons:图标
[12]IndexedList:索引列表
[13]List:列表
[14]LoadMore:加载更多
[15]NavBar:自定义导航栏
[16]NoticeBar:通告栏
[17]NumberBox:数字输入框
[18]Pagination:分页器
[19]PopUp:弹出层
[20]Rate:评分
[21]SearchBar:搜索栏
[22]SegmentedControl:分段器
[23]Steps:步骤条
[24]SwipeAction:滑动操作
[25]SwiperDot:轮播图指示点
[26]Tag:标签

23.使用Vue.prototype实现全局变量
解析:对于一个Vue脚手架项目来说,在main.js里使用Vue.prototype声明的变量,实际上是为Vue对象添加了一个原型属性,而不是一个全局变量。但是如果这个原型属性的值是引用类型的,就可以借此实现全局变量。

24.plus.screen.lockOrientation
解析:在html5+的api中有个锁定屏幕方向的方法是plus.screen.lockOrientation可以帮助解决屏幕旋转问题。如下所示:
[1]“portrait-primary”:竖屏正方向
[2]“portrait-secondary”:竖屏反方向,屏幕正方向按顺时针旋转180°
[3]“landscape-primary”:横屏正方向,屏幕正方向按顺时针旋转90°
[4]“landscape-secondary”:横屏方向,屏幕正方向按顺时针旋转270°
[5]“portrait”:竖屏正方向或反方向,根据设备重力感应器自动调整
[6]“landscape”:横屏正方向或反方向,根据设备重力感应器自动调整

25.plus.runtime
解析:通过plus.runtime可获取运行环境管理对象,如下所示:
[1]appid:当前应用的APPID
[2]arguments:第三方程序调用时传递给程序的参数
[3]launcher:应用启动来源
[4]origin:应用安装来源
[5]version:客户端的版本号
[6]innerVersion:客户端5+运行环境的版本号
[7]launchLoadedTime:获取当前应用首页加载的时间

参考文献:
[1]web-view:https://uniapp.dcloud.io/component/web-view
[2]HTML5+ API Reference:http://www.html5plus.org/doc/h5p.html
[3]uni-app开源案例:https://uniapp.dcloud.io/casecode
[4]uni-app插件市场:https://ext.dcloud.net.cn/
[5]dcloudio/uni-template-news:https://github.com/dcloudio/uni-template-news
[6]dcloudio/uni-ui:https://github.com/dcloudio/uni-ui

你可能感兴趣的:(开发工具,web-view,uni-app,uni-ui,h5,plus.runtime)