微信小程序初学一周
来源:互联网 发布:社会生存法则 知乎 编辑:程序博客网 时间:2024/05/29 13:10
7.12-7.17学习心得
初学的一个星期比较水,因为假期也有其他事要忙,还要去学车。所以没有记录学习,主要是刚刚有这个想法去记录。不过还好,之前的学习有记笔记,也有代码练习。只要整理一下再上传就好。
我先是在前人的学习心得里学习了app.js、app.json、app.wxss、app.wxml的作用,里面的属性。
app.json ##
官方API:我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径、窗口表现、设置网络超时时间、设置多 tab 等。
app.json 配置项列表
心得:目前的学习只用到了pages、window、tabBar三个属性。
(1)pages(Array)
官方:接受一个数组,每一项都是字符串,来指定小程序由哪些页面组成。每一项代表对应页面的【路径+文件名】信息,数组的第一项代表小程序的初始页面。小程序中新增/减少页面,都需要对 pages 数组进行修改。
文件名不需要写文件后缀,因为框架会自动去寻找路径.json,.js,.wxml,.wxss的四个文件进行整合。
心得:配置小程序的页面,必填。第一行为初始页面。定义或删除页面需要在pages里修改。接受字符串数组,每一项为【路径+文件名】,第一项为初始页面。文件名不需要写后缀,框架可以自己寻找路径,只在app.json中进行配置。
(2)window
官方:用于设置小程序的状态栏、导航条、标题、窗口背景色
心得:具体使用官方API很清晰了,在其他页的json中,因为只需要改window这个属性,所以不用widow{}的形式配置,只需要直接修改window中的属性即可。
(3)tabBar
官方:如果我们的小程序是一个多 tab 应用(客户端窗口的底部或顶部有 tab 栏可以切换页面),那么我们可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页面。
Tip:
当设置 position 为 top 时,将不会显示 icon
tabBar 是一个数组,只能配置最少2个、最多5个 tab,tab 按数组的顺序排序。
属性说明:
其中 list 接受一个数组,数组中的每个项都是一个对象,其属性值如下:
心得:这里的属性还是要在实践中去感受,现在还没有应用太多。在之后的学习中如果有什么需要注意的再来修改。
剩下的两个属性因为还没有应用过,所以先不总结了。
pages.json中只需要配置window就好!
之后还学习了app.js,开始做页面功能的时候在.js里进行,也需要注册。用Page()函数来注册知道了他是入口文件,对app进行注册并且对对生命周期函数监听。包括onLaunch()、onShow()、onHide()等函数,对处在不同生命周期的函数进行监听并执行一些功能。
App() 注册程序
App() 函数用来注册一个小程序。接受一个 object 参数,其指定小程序的生命周期函数等。
object参数说明:
前台、后台定义: 当用户点击左上角关闭,或者按了设备 Home 键离开微信,小程序并没有直接销毁,而是进入了后台;当再次进入微信或再次打开小程序,又会从后台进入前台。需要注意的是:只有当小程序进入后台一定时间,或者系统资源占用过高,才会被真正的销毁。
关闭小程序(基础库版本1.1.0开始支持): 当用户从扫一扫、转发等入口(场景值为1007, 1008, 1011, 1025)进入小程序,且没有置顶小程序的情况下退出,小程序会被销毁。 小程序运行机制在基础库版本 1.4.0 有所改变: 上一条关闭逻辑在新版本已不适用,详情
示例代码:
App({
onLaunch: function(options) {
// Do something initial when launch.
},
onShow: function(options) {
// Do something when show.
},
onHide: function() {
// Do something when hide.
},
onError: function(msg) {
console.log(msg)
},
globalData: ‘I am global data’
})
onLaunch, onShow 参数
getApp()
我们提供了全局的 getApp() 函数,可以获取到小程序实例。
// other.js
var appInstance = getApp()
console.log(appInstance.globalData) // I am global data
注意:
App() 必须在 app.js 中注册,且不能注册多个。
不要在定义于 App() 内的函数中调用 getApp() ,使用 this 就可以拿到 app 实例。
不要在 onLaunch 的时候调用 getCurrentPages(),此时 page 还没有生成。
通过 getApp() 获取实例之后,不要私自调用生命周期函数。
page() 注册页面
Page() 函数用来注册一个页面。接受一个 object 参数,其指定页面的初始数据、生命周期函数、事件处理函数等。
object 参数说明:
示例代码:
//index.js
Page({
data: {
text: “This is page data.”
},
onLoad: function(options) {
// Do some initialize when page load.
},
onReady: function() {
// Do something when page ready.
},
onShow: function() {
// Do something when page show.
},
onHide: function() {
// Do something when page hide.
},
onUnload: function() {
// Do something when page close.
},
onPullDownRefresh: function() {
// Do something when pull down.
},
onReachBottom: function() {
// Do something when page reach bottom.
},
onShareAppMessage: function () {
// return custom share data when user share.
},
onPageScroll: function() {
// Do something when page scroll
},
// Event handler.
viewTap: function() {
this.setData({
text: ‘Set some data for updating view.’
})
},
customData: {
hi: ‘MINA’
}
})
this.setData{}中的内容相当于在data中定义过。
- 微信小程序初学一周
- 初学一周犯错经验总结
- 程序猿的一周
- 第一周阅读程序
- 第十一周 阅读程序
- 第十一周阅读程序
- 第十一周阅读程序
- 第十一周阅读程序
- 第十一周阅读程序
- 第十一周程序阅读
- 第十一周阅读程序
- 初学小程序1
- gdb调试程序初学
- 初学java程序
- python初学程序
- php初学程序备份
- c++之初学程序
- 初学C程序
- Spring Boot项目部署(Linux、maven)
- 几种C++ std::string和std::wstring相互转换的转换方法
- Rescue(优先队列+bfs)
- 访问有授权验证的 Redis
- mybatis oracle下不同表空间表名重复与批量删除,新增
- 微信小程序初学一周
- [UVa1625]颜色的长度
- php无法获取angularjs post数据
- ubuntu16.04 x64上nginx源码安装
- 每日一发Python---Python中双冒号的作用[::]
- 动态内存
- iOS10个实用小技巧
- librtmp获取视频流和音频流1
- java 调用bat文件