1、服务号:给企业和组织提供更强大的业务服务与用户管理能力,帮助企业快速实现全新的公众号服务平台。
2、订阅号:为媒体和个人提供一种新的信息传播方式,构建读者之间更好的沟通与管理模式
3、小程序:一种新的开放能力,可以在微信内被编辑的获取和传播,同时具有出色的使用体验
1、在微信公众平台注册开发者账号
2、填写注册信息
3、填写用户登记信息
4、填写小程序信息
1、访问官方网站,下载最新版开发工具
2、安装开发工具
3、创建项目
注意:项目目录严禁出现中文或空格并选择不使用云服务
微信开放文档微信开发者平台文档https://developers.weixin.qq.com/miniprogram/dev/framework/
1、小程序的文件类型有:
app.json:全局配置
page.json:页面配置,其优先级高于全局配置
不能使用任何的HTML标签,只能使用小程序专用的组件
app.wxss,全局样式
page.wxss,页面样式,其优先级高于全局样式
app.js,小程序的入口脚本文件
page.js,页面的脚本文件
app.json、app.wxss、app.js文件必须储存在小程序的跟目录下
1.pages属性:pages属性用于指定小程序由哪些页面组成,每个页面由 .json、 .wxml 、 .wxss和 .js组成
:谁在前谁显示,只能创建新的文件,并不能删除新的文件,需要在目录树中自己删除
2.window属性:用于设置小程序导航栏、标题、窗口背景颜色等信息,object类型。
"window":{
"navigationBarTitleText": "Weixin", //标题文本
"navigationBarBackgroundColor": "#fff", //标题栏背景颜色 (只认定#十六进制颜色)
"navigationBarTextStyle":"black", //标题文本颜色(white | black)
"enablePullDownRefresh":true, //开启下拉刷新(true | false)
"backgroundTextStyle":"light", //下拉刷新loading的样式(light | dark)
"backgroundColor":"#eee", //下拉刷新窗口的背景颜色
},
3.tabBar属性:用于配置小程序底部的选项卡,object类型
list中至少包含2-5个选项卡;pagePath不能以/开头;
iconPath 和 selectedIconPath 不能使用网络路径;
图片尺寸建议为81x81,字节数不能超过40KB
"tabBar":{
"position": "选项卡的位置(top | bottom)", //一般为bottom
"color": "文本正常显示的颜色",
"selectedColor":"文本被选中时的颜色",
"backgroundColor":"底部选项卡的背景颜色",
"borderStyle":"选项卡上边框的颜色(black | white)",
"list":[ ... ] //在list中配置每个选项卡的基本信息
},
"list":[
{
"text": "文本内容",
"pagePath": "页面的路径",
"iconPath":"正常显示时的图片路径",
"selectedIconPath":"被选中时的图片路径"
}
]
{
"pages":[
"pages/index/index",
"pages/logs/logs",
"pages/cart/cart",
"pages/me/me",
"pages/theatre/theatre"
],
"window":{
"enablePullDownRefresh":true,
"backgroundColor": "#eee",
"backgroundTextStyle":"dark",
"navigationBarBackgroundColor": "#a00",
"navigationBarTitleText": "学子影院",
"navigationBarTextStyle":"black"
},
"tabBar": {
"borderStyle": "black",
"color": "#222",
"selectedColor": "#a00",
"position": "bottom",
"list": [
{
"text": "首页",
"pagePath":"pages/index/index",
"iconPath": "/images/index_disable.png",
"selectedIconPath": "/images/index_enable.png"
},
{
"text": "影院",
"pagePath":"pages/theatre/theatre",
"iconPath": "/images/theatre_disable.png",
"selectedIconPath": "/images/theatre_enable.png"
},
{
"text": "我的",
"pagePath":"pages/me/me",
"iconPath": "/images/me_disable.png",
"selectedIconPath": "/images/me_enable.png"
}
]
},
"style": "v2",
"sitemapLocation": "sitemap.json"
}
4.style属性:用于指定样式,目前值仅为v2(要求基础库版本>=2.8),string类型
siteMapLocation属性:用于指定sitemap.json文件的位置,string类型
siteMap配置:微信开放小程序内搜索,开发者可以通过sitemap.json配置,或者管理后台页面收录开关来配置其小程序页面是否允许微信索引。当开发者允许微信索引时,微信会通过爬虫的形式,为小程序的页面内容建立索引。
siteMap.josn用于制定爬虫的搜索规则,其基本结构是:
{
"rules":[
{
"action":"动作类型(allow | disallow)", //允许或不允许
"page":"页面路径",
"params":["路径参数1","路径参数2"],
"matching":"匹配规则(exact | inclusive | exclusive | partial)"
}
]
}
路径参数指:pages/article/article?cid=6&order=time 中的cid和order
matching的规则包括:
exact 完全相同
inclusive 包含
exclusive 不包含
partial 部分包含
siteMap配置示例,若如下图所示配置,则:
path/to/page?a=1&b=2 命中
path/to/page?a=1&b=2&c=3 命中 (因为上面的matching为inclusive)
5.JSON文件不能书写注释
6.字符串必须括在英文双引号之间
7.数组中最后一个成员后不能存在逗号
8.JSON中不能存在undefined数据类型(可以用null)
小程序官方提供了组件库用于渲染基本页面结构。除此依然有一些团队开发了第三方组件库。小程序官方提供的组件库主要包括以下部分:
小程序官方提供了小程序组件库演示项目,在微信中搜索”小程序示例“即可
小程序提供的组件基本语法如下:
<组件名
组件属性 = "组件属性值"
组件属性 = "组件属性值"
组件属性 = "组件属性值"
组件名>
hover-class:"按下去的WXSS样式类名称"
hover-start-time="多久后出现点击状(50)"
hover-stay-time="点击状保持的时长(400)"
hover-stop-propagation="是否阻止冒泡">
//冒泡:点击子view时,父view也出现点击态,但不论设置true还是false时,都会有该效果;是因为该属性类型是boolean,上面的属性类型都是string;但是对于标签来说,我们引入一个属性,对属性赋值使用双引号,双引号内部永远都是字符串型,对于字符串“true”和“false”,boolean类型永远都会解析为ture;若写的是空字符串 "",则会被解析为false
还有一个方法就是利用双花括号:
hover-stop-propagation="{ {ture} }" /true
hover-stop-propagation="{ {false} }" /false
. . .
案例:
app.json
"pages":[
"pages/testing/view/view",
"pages/index/index",
"pages/logs/logs",
"pages/cart/cart",
"pages/me/me",
"pages/theatre/theatre"
],
view.wxml
view.wxss
.myview{
margin-top: 10px;
width: 200px;
height: 200px;
border: 1px solid black;
background-color: #eee;
}
.myhoverview{
background-color: cornflowerblue;
}
.mychild{
width: 100px;
height: 100px;
margin: 30px;
border: 1px solid black;
background-color: darkcyan;
}
.myhoverchild{
background-color: firebrick;
}
src = "图片的url地址" //本地路径和网络路径都可以
lazy-load = "是否采用懒加载" //boolean类型属性
show-menu-by-longpress = "长按是否显示识别小程序码的菜单"
mode = "图像裁切及缩放模式">
widthFix:缩放模式,宽度不变,高度自动变化,保持原图宽高比不变
heightFix:缩放模式,高度不变,宽度自动变化,保持原图宽高比不变
top:裁剪模式,不缩放图片,只显示图片的顶部区域
bottom:裁剪模式,不缩放图片,只显示图片的底部区域
center:裁剪模式,不缩放图片,只显示图片的中间区域
left:裁剪模式,不缩放图片,只显示图片的左边区域
right:裁剪模式,不缩放图片,只显示图片的右边区域
top left:裁剪模式,不缩放图片,只显示图片的左上边区域
top right:裁剪模式,不缩放图片,只显示图片的右上边区域
bottom left:裁剪模式,不缩放图片,只显示图片的左下边区域
bottom right:裁剪模式,不缩放图片,只显示图片的右下边区域
设备 | rpx换算px(屏幕宽度/750) | px换算rpx(750/屏幕宽度) |
iPhone5 | 1rpx = 0.42px | 1px = 2.34rpx |
iPhone6 | 1rpx = 0.5px | 1px = 2rpx |
iPhone6 Plus | 1rpx = 0.552px | 1px = 1.81rpx |
无论任何屏幕宽度为750rpx
autopaly="是否自动播放"
indicator-dots="是否显示指示标志"
indicator-color="指示标志正常显示的颜色"
indicator-active-color="提示标志被选定时的颜色"
circular="是否采用衔接滑动"
interval="自动切换的时间间隔"
duration="切换的时长">
. . . . . .
app.json
"pages":[
"pages/testing/swiper/swiper",
"pages/index/index",
"pages/logs/logs",
],
swiper.wxml
swiper.wxss
swiper image{
/* 如果把height写死的话,换成不同的设备,图片不一定能完整的显示,
此时我们可以用比例计算height:原图的宽:现图的宽 = 原图的高:现图的高,
就可以求出现在我们应该设置的height为多少了;但是显示的图片不仅仅只跟
image有关,还要设置相应的swiper的height,否则在不同设备中效果依旧不同*/
width: 750rpx; height: 220.7rpx; }
swiper{ height: 220.7rpx; }
注意:在 text 组件中写 image 是无效的
//全部为boolean类型数据
scroll-x = "是否允许水平滚动"
scroll-y = "是否允许垂直滚动"
enable-flex = "是否启用flex布局"
enhanced = "是否启用增强特性"
showScrollbar = "是否显示滚动条"> //想要启动该属性,就必须要开启enhanced属性:enhanced = "true"
. . .
scrollview.wxml
吴磊
吴磊
吴磊
吴磊
吴磊
吴磊
吴磊
scrollview.wxss
.scroll{
display: flex;
}
.item{
width: 100px; height: 160px; margin: 10px 10px;
}
.item text{
display: block;text-align: center;
}
url = "当前小程序内的页面路径"
open-type = "跳转方式"
hover-class = "按下去的wxss样式类名称"
hover-start-time = "多久后出现点击状(50)"
hover-stay-time = "是点击状保持的时长(600)"
hover-stop-propagation = "是否阻止冒泡">
. . .
注意:小程序最多只能跳转10个页面。
点击返回时,该页面会销毁自身,
回到上上页时,上一页去哪了?——这两页都会被销毁
app.json
"pages":[
"pages/testing/a/a",
"pages/testing/b/b",
"pages/testing/c/c",
"pages/testing/scrollview/scrollview",
"pages/testing/text/text",
"pages/testing/swiper/swiper",
"pages/testing/image/image",
"pages/testing/view/view",
"pages/index/index",
"pages/logs/logs",
"pages/cart/cart",
"pages/me/me",
"pages/theatre/theatre"
],
a.wxml
我是A,点我navigator到B。
b.wxml
我是B,点我navigator到C。
我是B,点我redirect到C。
c.wxml
我是C,点我navigator到A。
我是C,点我回到B。
我是C,点我回到A。
我是C,点我回到index。
我是C,reLaunch到index,这个过程将销毁所有非tabBar页面。
type = "输入框类型"
placeholder = "占位符内容"
value = "初始内容"
password = "是否为密码"
maxlength = "最大长度"
focus = "是否自动获取焦点"
bindinput = "输入时触发的函数名称(只写函数名称,坚决不能带小括号)"
bindfocus = "获得焦点时触发的函数名称"
bindblur = "失去焦点时触发的函数名称">
值 | 说明 | 最低版本 |
text | 文本输入键盘 | |
number | 数字输入键盘 | |
idcard | 身份证输入键盘 | |
digit | 带小数点的数字键盘 |
input.wxml
测试input组件
input.wxss
input{
margin: 10px; padding: 5px; border: 1px solid gray;
}
值 | 说明 | 最低版本 |
send | 右下角按钮为”发送“ | |
search | 右下角按钮为”搜索“ | |
next | 右下角按钮为”下一个“ | |
go | 右下角按钮为”往前“ | |
done | 右下角按钮为”完成“ |
案例:新建页面测试input组件的使用,测试步骤如下:
获取触发input事件的表单组件的value时,必须在事件处理函数中带有`event`参数,该参数代表事件对象,可以通过该对象的`detail`属性获取相关的信息,示例代码如下:
Page({
inputEvent(event){
console.log(event.detail.value)
}
})
在文本框中,每输入一个字母,都会有对应的事件触发,可以在调试器中看到并且根据detail找到数据
输出event.detail.value,可以在调试器中拿到任意时刻的值
Page({
data: {
val:''
},
inputEvent(event){
this.setData({
val : event.detail.value
})
}
})
{{val}}
在text文本框中输入什么内容,“ input:”这行就会实时更新什么内容,这就是双向数据绑定
. . .
A.选项A内容
B.选项B内容
C.选项C内容
D.选项D内容
/* 当前修改单选按钮的选中项后触发 */
changeRadio(event){
console.log(event.detail.value)
this.setData({
val:event.detail.value
})
},
您选择的是:{{val}}
. . . . . .
checkboxgroup.wxml
【多选】请选择您的爱好:
健身
游泳
瑜伽
拉丁
您选择的爱好有:{{val}}
checkboxgroup.js
/*** 页面的初始数据 */
data: {
val : ['健身']
},
/* 当修改多选框选中状态时触发事件 */
changeCheckbox(event){
console.log(event.detail.value);
this.setData({
val:event.detail.value
})
},
checkboxgroup.wxss
checkbox{
display: block; margin: 10px;
}
check = "是否被选定"
color = "颜色"
type = "样式(switch | checkbox)"
bindchange = "选定项发生改变时触发的函数名称">
. . .
switch.js
data: {
flightOn: false
},
/* 当更改开关状态时触发 */
changeSwitch(event){
console.log(event.detail.value);
this.setData({
flightOn:event.detail.value
})
},
switch.wxss
.line{
margin: 10px; line-height: 32px;
}
.line switch{
float: right;
}
switch.wxml
打开飞行模式
当前飞行模式的状态:{{flightOn?'打开':'关闭'}}
<组件名称
wx: for = "{ {变量名称} }"
wx: for-item = "成员变量名称"
wx: for-index = "成员索引变量名称"
wx: key = "index">
. . .
组件名称>
- 条件渲染的使用方式有如下几种:
<组件名称 wx:if = "{{条件表达式}}"> ... 组件名称> <组件名称 wx:if = "{{条件表达式}}"> ... 组件名称> <组件名称 wx:else> ... 组件名称> <组件名称 wx:if = "{{条件表达式}}">...组件名称> <组件名称 wx:elif = "{{条件表达式}}">...组件名称> ... <组件名称 wx:else>...组件名称>
姓名:{{username}}
年龄:{{age}}
性别:{{gender}}
学校名称:{{school.name}}
学校地址:{{school.loc}}
学历:
专科
本科
研究生
博士生
{{item}}
/* pages/testing/wxml/wxml.wxss */
image.small{
width: 50px; height: 70px; margin: 10px;
}
image.big{
width: 100px; height:140px; margin: 10px;
}
.avatar-view{
display: inline-block; width: 100px; height: 140px; margin: 10px;
background-size: 100px 140px; /* 改变图片的尺寸 */
background-image: url();
}
.hobby-item{
display: inline-block; margin-left: 10px; border: 1px solid black;
background-color: #33a; padding: 0px 10px; color: white;
}
// pages/testing/wxml/wxml.js
Page({
/**
* 页面的初始数据
*/
data: {
education: 4,
size: 100,
avatarClass:'big',
pic: 1,
username:'然然',
age:18,
gender:'男',
hobby:['健身','游泳','瑜伽'],
school:{
name:'北京大学',
loc:'北京海淀'
}
},
/* 当点击图片后触发 */
tapImage(){
//修改pic的值 1->2 2->3 3->1
this.setData({
// 动态引入变量
pic: this.data.pic % 3 +1
})
},
...
)}
.container{ width:750rpx; height:100px; background-image:url(http://www.tmooc.cn/static/logo.png); } .container{ width:750rpx; height:100px; background-image:url( ); }
- 图片转 BASE64 编码 | 菜鸟工具Base64 是一种基于 64 个可打印字符来表示二进制数据的表示方法。 Base64 常用于在通常处理文本数据的场合,表示、传输、存储一些二进制数据,包括 MIME 的电子邮件及 XML 的一些复杂数据。 图片的 BASE64 编码就是可以将一幅图片数据编码成一串字符串,使用该字符串代替图片地址,从而不需要使用图片的 URL 地址。 图片转 BASE64 编码工具提供了 PNG 转换 Base64,GIF 转换 Base64,JPEG..https://c.runoob.com/front-end/59/(在这里可以将图片转换为base64)
<组件名称 bind事件名称 = "事件处理函数名臣"> . . . 组件名称>
<组件名称 bind:事件名称 = "事件处理函数名臣"> . . . 组件名称>
<组件名称 catch:事件名称 = "事件处理函数名臣"> . . . 组件名称>
案例:编写测试代码测试三种绑定事件的方式与小程序时间管理的特点
// pages/testing/event/event.js
tapInner(){
console.log('tapInner..');
},
tapOuter(){
console.log('tapOuter..');
},
/* pages/testing/event/event.wxss */
.outer{
width: 200px; height: 200px; border: 1px solid black;
}
.inner{
width: 100px; height: 100px; border: 1px solid red; margin: 50px;
}
小米 2999.0 京东
tapEvent(event){
//当前触发事件的事件源对象中绑定的data-id属性值
let id = event.target.dataset.id
let name = event.target.dataset.name
}
商品名称:{{item.name}}
商品单价:{{item.price}}
商品数量:{{itme.num}}
/* pages/testing/eventparams/eventparams.wxss */
.item{
margin: 10px; padding: 0px 10px;
}
// pages/testing/eventparams/eventparams.js
Page({
/*** 页面的初始数据 */
data: {
products:[{
name: '小米',
price: 2999,
num: 2,
},{
name: '华为',
price: 5999,
num: 3
},{
name: 'Oppo',
price: 4999,
num: 5
},{
name: '苹果',
price: 6999,
num: 4
}]
},
/* 点击删除按钮后执行 */
tapDel(event){
let index = event.target.dataset.index;
// 删除该index位置的元素
let prolist = this.data.products;
prolist.splice(index,1);
// 更新页面需要把prolist替换掉data中的products
this.setData({
products: prolist
})
},
...
})
获取文本输入框中的内容的语法: event.detail.value ==> "xxx"
获取picker中当前选中的项的语法: event.detail.value ==> 0 | [1,2]
获取switch中当前状态的语法: event.detail.value ==> true | false
待办事项列表
提示:当前没有待办事项
{{index+1}}.{{item}}
/* pages/testing/todo/todo.wxss */
.h1{
font-size: large; font-weight: bolder;
}
.todo-header{
float: left; margin: 10px 0px;
}
.todo-header input{
width: 220px; height: 30px; border: 1px solid gray;
}
.todo-header button{
width: 150px; height: 28px;line-height: 14px;margin: -30px 0px 0px 224px;
}
.todo-list-item{
margin: 20px 0px;
}
.todo-list-item button{
width: 100px;
float: right;
}
// pages/testing/todo/todo.js
Page({
/**
* 页面的初始数据
*/
data: {
todolist:['一点半开会','发邮件','聚餐'],
val : ''
},
inputEvent(event){
this.setData({
val:event.detail.value
})
},
tapEvent(event){
let val = this.data.val;
if(val.trim()==''){
return;
}
/* 追加到当前todolist中 */
let list = this.data.todolist;
list.push(val);
/* 更新页面 */
this.setData({
todolist: list,
val:'' /* 添加完后文本框内容清空 */
})
},
tapDelEvent(event){
let index = event.target.dataset.index;
//删除元素
let list = this.data.todolist;
list.splice(index,1);
//更新列表
this.setData({
todolist: list
})
},
...
})
属性 | 类型 | 默认值 | 必填 | 说明 |
success | function | 否 | 接口调用成功的回调函数 | |
fail | function | 否 | 接口调用失败的回调函数 | |
complete | function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
属性 | 类型 | 默认值 | 必填 | 说明 |
title | string | 是 | 提示的内容 | |
mask | boolean | false | 否 | 是否显示透明蒙层,防止触摸穿透 |
success | function | 否 | 接口调用成功的回调函数 | |
fail | function | 否 | 接口调用失败的回调函数 | |
complete | function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
属性 | 类型 | 默认值 | 必填 | 说明 |
success | function | 否 | 接口调用成功的回调函数 | |
fail | function | 否 | 接口调用失败的回调函数 | |
complete | function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
// pages/testing/todo/todo.js
tapEvent(event){
let val = this.data.val;
if(val.trim()==''){
return;
}
//添加之前(模拟发请求之前)先显示一个loading对话款
wx.showLoading({
title: '添加中,请稍后...',
mask:true
})
/* 追加到当前todolist中 */
let list = this.data.todolist;
list.push(val);
/* 更新页面 */
this.setData({
todolist: list,
val:'' /* 添加完后文本框内容清空 */
})
wx.hideLoading()
//调用微信提供的方法,弹出吐司提示框
wx.showToast({
title: '添加成功',
duration: 5000, //5s
icon:"success",
mask:true //为true时,后面的删除按钮是不可以点击的
})
},
tapDelEvent(event){
wx.showLoading({
title: '删除中,请稍后',
mask:true
})
let index = event.target.dataset.index;
//删除元素
let list = this.data.todolist;
list.splice(index,1);
//更新列表
this.setData({
todolist: list
})
wx.hideLoading()
},
属性 | 类型 | 默认值 | 必填 | 说明 |
title | string | 是 | 提示的内容 | |
content | string | 否 | 提示的内容 .editable 为true时,会输入框默认文本 | |
editable | boolean | false | 否 | 是否显示输入框 |
placeholderText | string | 否 | 输入框提示文本 | |
showCancel | boolean | true | 否 | 是否显示取消按钮 |
cancelText | string | '取消' | 否 | 取消按钮的文字,最多4个字符 |
cancelColor | string | #000000 | 否 | 取消按钮的文字颜色,必须是16进制格式的颜色字符串 |
confirmText | string | '确定' | 否 | 确定按钮的文字,最多4个字符 |
confirmColor | string | #576B95 | 否 | 确定按钮的文字颜色,必须是16进制格式的颜色字符 |
// pages/testing/todo/todo.js
tapDelEvent(event){
//弹出模态对话框,询问用户,是否确认删除?
wx.showModal({
title:'提示',
content:'确认删除吗?',
showCancel:true,
cancelText:'放弃不删', /* 不能超过四个字符 */
cancelColor: 'cancelColor',
confirmText:'残忍删除',
confirmColor:'#f00',
success:(result)=>{
if(result.confirm){
wx.showLoading({
title: '删除中,请稍后',
mask:true
})
let index = event.target.dataset.index;
//删除元素
let list = this.data.todolist;
list.splice(index,1);
//更新列表
this.setData({
todolist: list
})
wx.hideLoading()
}
}
})
},
// pages/testing/wxa/wxa.js
Page({
/**
* 页面的初始数据
*/
data: {
city:'未选择'
},
tapToB(){
wx.navigateTo({
url: '/pages/testing/wxb/wxb',
})
},
tapToChooseCity(){
wx.navigateTo({
url: '/pages/testing/wxb/wxb',
events:{
acceptCityFromB:(data)=>{
this.setData({
city:data
})
}
}
})
},
...
})
北京
杭州
上海
深圳
// pages/testing/wxb/wxb.js
Page({
/**
* 页面的初始数据
*/
data: {
},
tapCity(event){
let city = event.target.dataset.city;
//把city回传给A页面
let ec = this.getOpenerEventChannel();
ec.emit('acceptCityFromB',city);
wx.navigateBack();/* 点击完成后自动返回 */
},
...})
onLoad | function | 生命周期回调——监听页面加载 |
onShow | function | 生命周期回调——监听页面显示 |
onReady | function | 生命周期回调——监听页面初次渲染完成 |
onHide | function | 生命周期回调——监听页面隐藏 |
onUnload | function | 生命周期回调——监听页面卸载 |
生命周期 | 微信开放文档微信开发者平台文档https://developers.weixin.qq.com/miniprogram/dev/framework/app-service/page-life-cycle.html
// pages/testing/a/a.js
Page({
...
/*** 生命周期函数--监听页面加载 */
onLoad(options) {
console.log('A onLoad...')
},
/*** 生命周期函数--监听页面初次渲染完成 */
onReady() {
console.log('A onReady...')
},
/*** 生命周期函数--监听页面显示 */
onShow() {
console.log('A onShow...')
},
/*** 生命周期函数--监听页面隐藏 */
onHide() {
console.log('A onHide..')
},
/*** 生命周期函数--监听页面卸载 */
onUnload() {
console.log('A onUnload...')
},
...})
// pages/testing/b/b.js
Page({
...
/*** 生命周期函数--监听页面加载 */
onLoad(options) {
console.log('B onLoad...')
},
/*** 生命周期函数--监听页面初次渲染完成 */
onReady() {
console.log('B onReady...')
},
/*** 生命周期函数--监听页面显示 */
onShow() {
console.log('B onShow...')
},
/*** 生命周期函数--监听页面隐藏 */
onHide() {
console.log('B onHide..')
},
/*** 生命周期函数--监听页面卸载 */
onUnload() {
console.log('B onUnload...')
},
...})
// pages/testing/c/c.js
Page({
...
/*** 生命周期函数--监听页面加载 */
onLoad(options) {
console.log('C onLoad...')
},
/*** 生命周期函数--监听页面初次渲染完成 */
onReady() {
console.log('C onReady...')
},
/*** 生命周期函数--监听页面显示 */
onShow() {
console.log('C onShow...')
},
/*** 生命周期函数--监听页面隐藏 */
onHide() {
console.log('C onHide..')
},
/*** 生命周期函数--监听页面卸载 */
onUnload() {
console.log('C onUnload...')
},
...})
属性 | 类型 | 默认值 | 必填 | 说明 |
onLaunch | function | 否 | 生命周期回调——监听小程序初始化 | |
onShow | function | 否 | 生命周期回调——监听小程序启动或切前台 | |
onHide | function | 否 | 生命周期回调——监听小程序切后台 | |
onError | function | 否 | 错误监听函数 |
两种方法使两个页面交互
// pages/testing/wxa/wxa.js
Page({
/**
* 页面的初始数据
*/
data: {
city:'未选择'
},
tapToB(){
wx.navigateTo({
url: '/pages/testing/wxb/wxb',
})
},
tapToChooseCity2(){
wx.navigateTo({
url: '/pages/testing/wxb/wxb',
})
},
tapToChooseCity(){
wx.navigateTo({
url: '/pages/testing/wxb/wxb',
events:{
acceptCityFromB:(data)=>{
this.setData({
city:data
})
}
}
})
},
/**
* 生命周期函数--监听页面加载
*/
onLoad(options) {
},
/**
* 生命周期函数--监听页面初次渲染完成
*/
onReady() {
},
/**
* 生命周期函数--监听页面显示
*/
onShow() {
// 从app的globalDtata中拿到city 给data赋值
this.setData({
city: getApp().globalData.city
})
},
...})
北京
杭州
上海
深圳
// pages/testing/wxb/wxb.js
Page({
/**
* 页面的初始数据
*/
data: {
},
tapCity(event){
let city = event.target.dataset.city;
// 把city存入app的globalData,退出当前页面后,在a页面中读取即可
let app = getApp();
app.globalData.city = city;
//把city回传给A页面
let ec = this.getOpenerEventChannel();
ec.emit('acceptCityFromB',city);
wx.navigateBack();/* 点击完成后自动返回 */
},
...})
// app.js
App({
onLaunch() {
// // 展示本地存储能力
// const logs = wx.getStorageSync('logs') || []
// logs.unshift(Date.now())
// wx.setStorageSync('logs', logs)
// // 登录
// wx.login({
// success: res => {
// // 发送 res.code 到后台换取 openId, sessionKey, unionId
// }
// })
console.log('App onLaunch...')
},
onHide(){
console.log('App onHide...')
},
onShow(){
console.log('App onShow...')
},
// globalData可以存储全局共享的数据,例如用户信息
//可以在任何小程序页面的js文件中获取当前App对象,访问globalData的属性
//page.js中如何存?app = getApp() app.globalData.user=xx
//page.js中如何取?app = getApp() app.globalData.user
globalData: {
userInfo: null,
city:''
}
})
try{
wx.setStorageSync('key','value')
} catch(e){
console.error(e)
}
参数名 | 类型 | 必填 | 说明 |
success | function | 否 | 接口调用成功的回调函数 |
fail | function | 否 | 接口调用失败的回调函数 |
complete | function | 否 | 接口调用结束的回调函数(调用成功、失败都会执行) |
其他 | Any | - | 接口定义的其他参数 |
wx.cloud.callFunction({
//云函数名称
name:'cloudFunc',
//传给云函数的参数
data:{
a:1,
b:2,
},
success:function(res){
console.log(res.result) //示例
},
fail:console.error
})
项目主功能 如下所示:
电影分类列表显示
触底分页加载
定位页面实现
实现详情页数据呈现
演职人员表实现
剧照列表实现
剧照大图浏览实现
评论列表实现
项目技术构架如下:
前端:微信小程序
后端:php(服务已上线)
通信协议:https
在小程序中访问网络接口有很多的限制,主要有如下几点:
域名只支持HTTPS协议
HTTPS(全称:Hyper Text Transfer Protocol over SecureSocket Layer),是以安全为目标的HTTP通道,在HTTP的基础上通过传输加密和身份认证保障了传输过程的安全性。HTTPS在HTTP的基础下加入SSL,HTTPS的安全基础使SSL,因此加密的详细内容就需要SSL。HTTPS存在不同于HTTP的默认端口及一个加密/身份验证层(在HTTP与TCP之间)。这个系统提供了身份验证与加密通讯方法。
域名必须经过ICP备案
Internet Content Provider,中文全称:网络内容提供商。ICP可以理解为向广大用户提供互联网信息业务和增值业务的电信运营商,是经国家主管部门批准的正式运营企业或部门。
小程序使用域名前必须设置通讯域名
登陆小程序后台。
开发 ->开发设置 ->服务器域名
添加成功后,在小程序开发工具中检查状态是否更新
对于每个接口,最多可以配置20个域名
域名不支持IP地址
不支持配置父域名,但使用子域名的情况
wx.request({
url:"服务器接口的地址",
method:"请求方式",
header:请求头(object),
data:请求参数(object),
success:res=>{
//...
},
fail:err=>{
//...
},
compelete:res=>{
//...
}
})
案例:测试公共接口,检查小程序网络API是否可用:
说明 | |
接口地址 | https://api.tedu.cn/index.php |
请求方式 | GET |
请求参数 | cid:类别 ID |
返回值 | 电影列表 |
————————————————— 根据学习进度更新笔记 ——————————————