微信小程序基础知识笔记
微信小程序笔记
文件构成
全局文件
- app.json
小程序全局配置文件,必要,自动生成
- app.js
小程序入口JS文件,一般只需申明全局变量、处理生命周期以及版本升级即可,必要
- app.wxss
小程序全局CSS样式文件,非必要
- app.wxml
小程序全局HTNL文件,非必要
页面文件
[page]为页面自定义名称,可随意,但建议具有语义性的命名
- [page].json
页面配置文件
- [page].js
页面JS文件,一般实现具体的逻辑处理、网络请求等
- [page].wxss
页面CSS样式文件
- [page].wxml
页面HTNL文件
基本原理
小程序分为两个部分 webview 和 appService 。其中webview主要用来展现UI,appService有来处理业务逻辑、数据及接口调用。
App()是小程序唯一实例,页面中可通过getApp()获取该实例,而Page()是页面实例。
// app.js
globalData: {
name: 'zzz'
}
// page.js
const name = getApp().globalData.name
生命周期
onLoad——页面加载,调一次,可在参数内获取跳转URL传递的参数
onShow——页面显示,每次打开/切入前台时页面都调用
onReady——初次渲染完成,调一次
onHide——页面隐藏/切入后台,当navigateTo或底部tab切换时调用
onUnload——页面卸载,当redirectTo或navigateBack时调用
graph LR
onLoad页面加载-->onShow页面显示
onShow页面显示-->onReady页面渲染
onReady页面渲染-->onHide页面隐藏/后台
onHide页面隐藏/后台-->onUnload页面卸载
基础语法
数据更新
小程序内数据更新必须使用setData函数异步更新
this.setData({
key: value
}, [function])
// 参数二为可选参数,接受一个函数作为异步更新数据的回调
数据获取
数据获取直接使用对象链即可
const name = this.data.name
数据绑定
插值表达式
{{ name }}
数据遍历
wx:for
wx:for="{{ array }}" wx:key="id"
// 默认:当前项item,索引index
{{ item.id }} - {{ index }}
// 可选参数
wx:for-item="myItem" wx:for-index="myIndex"
{{ myItem.id }} - {{ myIndex }}
条件
wx:if
wx:else
const isShow = true
wx:if={{ false }}
wx:else={{ isShow }}
...
跳转
内部跳转
- wx.navigateTo
保留当前页面,跳转到应用内的某个页面。但是不能跳到 tabbar 页面(参数必须为字符串)
wx.navigateTo({
url: `/pages/welcome/index?name=${name}`
})
- wx.redirectTo
关闭当前页面,跳转到应用内的某个页面。但是不允许跳转到 tabbar 页面
wx.redirectTo({
url: `/pages/welcome/index?name=${name}`
})
- wx.switchTab
跳转到 tabBar 页面,并关闭其他所有非 tabBar 页面,路径后不能带参数
wx.switchTab({
url: '/pages/index/index'
})
- wx.navigateBack
关闭当前页面,返回上一页面或多级页面。可通过 getCurrentPages() 获取当前的页面栈,决定需要返回几层
wx.navigateBack({
detal: 1
})
- wx.reLaunch
关闭所有页面,打开到应用内的某个页面
wx.reLaunch({
url: '/pages/index/index'
})
WXML标签,跳转任意页面,可添加属性实现跳转其他小程序
// page.wxml
<navigator url='/pages/index/index'>
// 跳转小程序
<navigator targe="miniProgram" app-id="123456789">
跳转外部小程序
- wx.navigateToMiniProgram
打开另一个小程序
wx.reLaunch({
appId: '12345678',
extraData: {} // 跳转参数
})
详细参数建议阅读 “wx.navigateToMiniProgram|微信开放文档”
- wx.navigateBackMiniProgram
返回上一个小程序
wx.reLaunch({
extraData: {} // 返回参数
})
跳转内嵌H5
web-view
承载网页的容器,每个页面只能有一个 web-view,会自动铺满整个页面,并覆盖其他组件。
跳转至web-view页面并赋值src属性即可
// page.wxml
<web-view src="{{url}}"></web-view>
详细内容建议阅读 “web-view|微信开放文档”(重要)
传参
函数传参
小程序函数传递参数语法区别于Vue,不能直接使用bindtap="handle(item)",需要使用 data- 属性绑定参数
// page.wxml
<view bindtap="handle" data-item="item">
// 多参数
<view bindtap="handle" data-item="{{ {item1, item2} }}">
<view bindtap="handle" data-item="{{ [item1, item2] }}">
// page.js
handle(e) {
const item = e.currentTarget.dataset.item
}
跳转传参
跳转页面path上直接拼接参数即可
wx.navigateTo({
url: '/pages/welcome/index?name=zzz'
})
// welcom/index.js
onLoad(options) {
const name = options.name // zzz
}
未完待续
微信小程序基础知识笔记的更多相关文章
- 微信小程序基础知识
一.基本目录结构 app.js 定义app入口 app.json 定义页面配置 index.js 页面中的事件和监听 index.wxml 定义布局文件 1.app.json配置基本信息 { “pag ...
- 微信小程序基础
前言 什么是微信小程序,它是一种轻量级的APP,它与常规App来说,无需下载安装即可使用,它嵌于微信App中,要使用微信小程序你只需要搜索一下微信小程序的名称就好,如近期的"Google的画 ...
- 微信小程序基础入门
准备 Demo 项目地址 https://github.com/zce/weapp-demo Clone or Download(需准备GIT环境) $ cd path/to/project/root ...
- 微信小程序内训笔记
2016年9月22日凌晨微信官方正式宣布“小程序”开始内测,有“微信之父”之称.腾讯集团高级执行副总裁张小龙在2016年末对外宣布“小程序“应用将于2017年1月9日正式推出 这一次微信还是按照惯例, ...
- 微信小程序基础之开源项目库汇总
awesome-github-wechat-weapp 是由OpenDigg整理并维护的微信小程序开源项目库集合.我们会定期同步OpenDigg上的项目到这里,也欢迎各位提交项目给我们. (链接:ht ...
- 一个C#程序员学习微信小程序路由的笔记
路由大家应该都知道,在微信小程序也是有的,毕竟它是单页面应用程序.在WeChat中有五种跳转方式,分别是wx.switchTab.wx.reLaunch.wx.redirectTo.wx.naviga ...
- 微信小程序基础之在微信上显示和体验小程序?
随着小程序正式上线,用户现在可以通过二维码.搜索等方式体验到开发者们开发的小程序了. 用户只要将微信更新至最新版本,体验过小程序后,便可在发现页面看到小程序TAB,但微信并不会通过这个地方向用户推荐小 ...
- 微信小程序基础之交互操作控件
好久没有写关于微信小程序的文章了,今天简单的发表一篇,内容比较简单,包括:ActionSheet上拉菜单.AlertAction提示框.SuccessAction完成框.LoadingAction加载 ...
- 微信小程序基础之input输入框控件
今天主要详写一下微信小程序中的Input输入框控件,输入框在程序中是最常见的,登录,注册,获取搜索框中的内容等等都需要,同时,还需要设置不同样式的输入框,今天的代码中都要相应的使用. input输入框 ...
随机推荐
- NPM 所有的指令已经问题 使用淘宝镜像 出现code EAI_AGAIN
windows怎么卸载cnpm? npm uninstall cnpm -g windows怎么检测cnpm是否安装成功 cnpm -v 我们直接将node的仓库地址换成淘宝仓库地址即可 单次使用 n ...
- PHP imap 远程命令执行漏洞(CVE-2018-19518)
影响版本 PHP:5.6.38 系统:Debian/ubuntu 构造数据包 成功执行命令echo '1234567890'>/tmp/test0001
- 解决ModuleNotFoundError: No module named 'pip'问题
Python学习遇到小问题:ModuleNotFoundError: No module named 'pip' 今天想要装一下第三方库exifread的时候发现cmd窗口下无法执行pip命令,想了想 ...
- 2020年度钻石C++C学习笔记(3)--《博学谷》
1.Unix/Linux操作系统介绍 1.1 操作系统的作用 1.1.1 操作系统的目标 l 方便:使计算机系统易于使用 l 有效:以更有效的方式使用计算机系统资源 l 扩展:方便用户有效开发.测试和 ...
- Java互联网架构师系统进阶课程 (一)【享学】
2.线程的并发工具类 Fork-Join 什么是分而治之? 规模为N的问题,N<阈值,直接解决,N>阈值,将N分解为K个小规模子问题,子问题互相对立,与原问题形式相同,将子问题的解合并得到 ...
- onethink-i春秋
记一道onethink漏洞拿flag的题. 因为用户名长度被限制了,注册两个账号分别为 %0a$a=$_GET[a];// %0aecho `$a`;// #(%0a是换行符的urlencode) 点 ...
- Using Evernote with Wine on Mint
Install Evernote Install Evernote in Wine: wine Evernote_xxx.exe; Backup Evernote Database File Loca ...
- 整理自己部署项目需要使用的Linux命令
1.修改文件名: mv test test 12.创建test文件夹: mkdir test3.解压文件至 test文件夹下: unzip test.war -d test/4.将work文件移动至 ...
- 聊一聊中台和DDD(领域驱动设计)
本次分享价值:本次分享主要针对中台.微服务和领域模型的理念.本质及其构建方法论进行探讨.对领域分析的价值所在就是寻求"千变万化"中相对的"稳定性.第一性",然后 ...
- 最短路径 | 深入浅出Dijkstra算法(一)
参考网址: https://www.jianshu.com/p/8b3cdca55dc0 写在前面: 上次我们介绍了神奇的只有五行的 Floyd-Warshall 最短路算法,它可以方便的求得任意两点 ...