知识点名称 | 知识点内容 | 难度系数 | 要求程度 |
---|---|---|---|
模板语法 | 数据绑定、事件绑定、条件渲染、列表渲染 | 2星 | 掌握 |
WXSS样式 | WXSS | 3星 | 掌握 |
配置操作 | 全局配置、TabBar配置、页面配置、 | 3星 | 掌握 |
网络请求和案例 | 网络数据请求、本地生活案例 | 3星 | 掌握 |
文章目录
- 1、学习目标
- 2、模板语法
- 2.1、数据绑定
- 数据绑定原则
- 动态绑定属性
- 2.2、事件绑定
- 什么是事件
- bindTap 的语法格式
- 事件对象
- target 和 currentTarget 的区别
- 为 data 中的数据赋值
- 事件传参
- bindinput的语法格式
- 模拟数据双向绑定
- 2.3、条件渲染
- if..elif..else
- 基于 block 标签使用 if 条件判断
- hidden
- if 和 hidden 的区别
- 2.4、列表渲染
- wx:for
- 手动指定索引和当前项的变量名
- wx:key 的使用
- 3、WXSS样式
- 什么是 wxss及和 css 之间的关系
- 什么是 rpx 及实现原理
- rpx 与 px 以及设计稿之间的换算关系
- @import 样式导入
- 全局样式和局部样式
- 4、配置操作
- 4.1、全局配置
- 全局配置文件以及常用的配置项
- 小程序窗口的组成
- 4.2、TabBar 配置
- Tab bar的概念
- TabBar 的组成部分
- TabBar 节点的配置项
- TabBar 案例
- 4.3、页面配置
- 页面配置文件的作用
- 页面配置和全局配置的关系
- 5、网络请求
- 5.1、小程序中网络数据请求的限制
- 5.2、配置 request 合法域名
- 5.3、发起 GET 请求
- 5.4、发起 POST 请求
- 5.5、在页面刚加载时请求数据
- 5.6、跳过 request 合法域名校验
- 5.7、关于跨域和 AJAX 的说明
- 5、案例
- 5.1、案例效果
- 5.2、实现思路
- 5.3、代码实现
思考
❓ Vue 中如何进行数据的渲染与属性绑定绑定?
- Vue 中重点使用 插值表达式 渲染数据
- 绑定的动态绑定使用 v-bind 语法或者 : 简写用法
1、基本原则
2、 在 data 中定义页面的数据
在页面对应的 .js 文件中,把数据定义在 data 对象中即可:
Page({
data:{
// 字符串类型的数据
name:'小程序',
// 数组类型的数据
info:[
{id:1,name:'Vue'},
{id:2,name:'React'}
]
}
})
3、Mustache 语法的格式
把 data 中的数据绑定到页面中渲染,使用 Mustache 语法 (双大括号) 将变量包起来即可。语法格式如下:
<view>
<view>{{ name }}view>
<view>{{ info[0].name }}view>
view>
1、Mustache 语法的应用场景
2、属性绑定
页面数据如下:
Page({
data:{
// 图片变量
imgSrc: 'https://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png'
}
})
页面结构如下:
<view>
<image src="{{ imgSrc }}" mode="aspectFit">image>
view>
3、三元运算
页面数据如下:
Page({
data:{
// 生成10以内的随机数
randomNum: Math.random() * 10
}
})
页面结构如下:
<view>
<view>{{ randomNum >5 ? '随机数大于5' : '随机数小于5' }}view>
view>
3、算术运算
页面数据如下:
Page({
data:{
// 生成100以内的随机数
randomNumber: Math.random().toFixed(2)
}
})
页面结构如下:
<view>
<view>{{ randomNumber * 100 }}view>
view>
<button bindtap="btnHandle" type="warn">按钮button>
Page({
btnHandle () {
console.log('触发事件')
}
})
当事件回调触发的时候,会收到一个事件对象 event,它的详细属性如下:
通过调用 this.setData(dataObject) 方法,可以给页面 data 中的数据重新赋值
this.setData() 方法有两个作用:1. 更新数据 , 2. 驱动视图更新
Page({
data: {
age:0
},
btnHandle (e) {
this.setData({
// 键需要更新的字段
// 值为最新的数据
age: this.data.age + 1
})
}
})
事件传参错误方式
小程序中的事件传参比较特殊,不能在绑定事件的同时为事件处理程序传递参数
例如,下面的代码将不能正常工作,因为小程序会把 bindtap 的属性值,统一当作事件名称来处理,相当于要调用一个名称为 btnHandler(123) 的事件处理函数
事件传参正确的方式
可以为组件提供 data-* 自定义属性传参,其中 *** 代表的是参数的名字**,示例代码如下:
<view>
<button bindtap="fn" data-id="{{ 123 }}">事件传参button>
view>
最终:
接收事件传递的参数
在事件处理函数中, **通过 event.target.dataset.参数名 **即可获得 具体的参数的值,示例代码如下:
Page({
fn (e) {
// dataset 是一个对象,包含了所有通过 data-* 传递的参数
console.log(e.target.dataset)
// 通过dataset 可以访问到具体的参数值
console.log(e.target.dataset.id)
}
})
在小程序中,通过 input事件来响应文本框的输入事件,语法格式如下:
<input type="input" bindinput="inputFn"/>
Page({
inputFn (e) {
// e.detail.value 是文本框最新的值
console.log(e.detail.value)
}
})
Page({
data:{
msg:'Hi~'
}
})
<input type="text" value="{{ msg }}" bindinput="inputFn" />
输入框的数据是==> {{ msg }}
input{
border:1px solid #ccc;
padding:5px;
margin:5px;
border-radius:3px;
}
Page({
inputFn(e){
// e.detail.value 是文本框最新的值
this.setData({
msg:e.detail.value
})
}
})
总结概况
❓ 小程序中事件如何传递参数?
- 为组件提供 data-* 自定义属性传参,其中 * 代表的是参数的名字
- 在事件处理函数中,通过 event.target.dataset.参数名 即可获取到具体参数的值
总结概况
❓ 如何获取到输入框最新的值
- 给 input 框绑定点击事件
- 通过事件对象 e.detail.value 获取到输入框最新的值
总结概况
❓ this.setData() 方法的作用是什么
- 更新数据
- 驱动视图更新
思考
❓ Vue 中如何进行条件渲染?
- v-if……v-else-if……v-else
- v-show
思考
❓ Vue 中两种条件渲染的区别是什么?
- v-if 会确保在切换过程中,将条件块内的事件监听器和子组件适当地被销毁和重建。
- v-show 不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换
<view wx:if="{{ condition }}">Trueview>
<view wx:if="{{ type === 1 }}">view>
<view wx:elif="{{ type === 2 }}">view>
<view wx:else>保密view>
如果要一次性判断多个组件标签,可以使用一个
标签将多个组件包装起来,并在上边使用 wx:if 控
制属性
<block wx:if="{{ true }}">
<view>View1view>
<view>View2view>
block>
注意:
并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性。
在小程序框架中,直接使用 hidden=“” 也能控制元素的显示与隐藏
<view hidden="{{ false }}">条件为true 隐藏, 条件false表示显示view>
思考
❓ Vue 中如何进行列表渲染 ?
使用 v-for 指令进行渲染,在渲染时给渲染的元素添加 :key 属性
思考
❓ key 的作用是什么 ?
指定列表中项目的唯一的标识符,让每一项保持自己的特征和状态
Page({
data:{
array:[
{ message:'Tom' },
{ message:'Jerrry' }
]
}
})
<view wx:for="{{ array }}" wx:key="index">
{{index}} : {{ item.message }}
view>
<view wx:for="{{ array }}" wx:for-item="itemName" wx:key-index="i" wx:key="i">
{{ i }} : {{ itemName.message }}
view>
如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态
(如 input 中的输入内容,switch 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符,从而提
高渲染的效率,示例代码如下
<view wx:for="{{ array }}" wx:key="index">
{{ index }} : {{ item.message }}
view>
什么是 rpx
rpx(responsive pixel) 是微信小程序独有的,用来解决屏幕适配的尺寸单位
rpx 的实现原理
rpx 是实现原理非常简单:鉴于不同设备屏幕的大小不同,为了实现屏幕的自动适配,*rpx 把所有设置的屏幕,在***宽度上 等分为 750 份,即 当前屏幕的总宽度为750 rpx
小程序在不同的设备上运行的时候,会自动把 rpx 的样式单位换算成对应的像素单位来渲染,从而显示屏幕适配
rpx 与 px 之间的换算
以 iPhone6 为例,iPhone6 的屏幕宽度为 375px ,共有 750 个物理像素。则 750rpx = 375px = 750 物理像素,即 1rpx = 0.5px = 1 物理像素
rpx 和 iPhone6 设计稿的关系
官方建议:开发微信小程序时,设计师可以用 iPhone6 作为视觉稿的标准。(iPhone6 设计稿宽度为 750px)
如果要根据 iPhone6 的设计稿,绘制小程序页面,可以直接把单位从 px 替换为 rpx
例如,假设 iPhone6 设计稿上,要绘制一个 宽高为 200px 的盒子,换算为 rpx 为 200rpx
@import '../../styles/global.wxss';
什么是全局样式
定义在 app.wxss 中的样式为全局样式,作用于每一个页面
局部样式
小程序根目录下的 app.json 文件用来对微信小程序进行全局配置。常用的配置如下:
小程序的窗口由 3 部分组成:导航栏区域、背景区域、页面主体区域
设置导航栏标题文字内容
设置步骤:app.json → window → navigationBarTitleText
设置导航栏背景色
设置步骤:app.json → window → navigationBarBackgroundColor
设置导航栏标题颜色
设置步骤:app.json → window → navigationBarTextStyle
注意:此选择仅支持 black / white
全局开启下拉刷新功能
通过手指在屏幕上的下拉滑动操作,从而重新加载页面数据的行为
设置步骤:app.json → window → enablePullDownRefresh
设置下拉刷新窗口的背景色
当全局开启下拉刷新功能之后,默认的窗口背景为白色
设置步骤:app.json → window → backgroundColor
设置下拉loading的样式
当全局开启下拉刷新功能之后,默认窗口的 loading 样式为白色
设置步骤:app.json → window → backgroundTextStyle
注意:仅支持 dark / light
设置上拉触底的距离
手指在屏幕上的上拉滑动操作,从而加载更多数据的行为
设置步骤:app.json → window → onReachBottomDistance
注意: 默认距离为 50px,如果没有特殊需求,建议使用默认值即可
注意:
tabBar 中,只能配置最少 2 个、最多 5 个 tab 页签,
当渲染顶部 tabBar 的时候,不显示 icon,只显示文本
根据素材中提供的小图标,实现下图中 TabBar 效果:
实现步骤
- 将 image 文件夹,拷贝到小程序项目根目录中
- 创建 3 个对应的 tab 页面
- 设置 tabBar 字段,同时设置 list 字段,配置 TabBar 即可
案例代码
"tabBar":{
"list":[
{
"pagePath":"pages/home/home",
"text":"首页",
"iconPath":"/images/tabs/home.png",
"selectedIconPath":"/images/tabs/home-active.png"
},
{
"pagePath":"pages/message/message",
"text":"消息",
"iconPath":"/images/tabs/message.png",
"selectedIconPath":"/images/tabs/message-active.png"
}
}
思考
❓ TabBar 配置项中注意事项
- List 配置项最多 5 个,最少 2 个
- 当 postision 的值为 Top 时,不显示 icon 图标
小程序每个页面都有自己的 .json 文件,用来对本页面的窗口表现进行配置。页面中配置项在当前页面会覆盖 app.json 的 window 中相同的配置项
小程序中, app.json 中的 window 节点,可以全局配置小程序中每个页面的窗口表现
如果某些小程序页面想要拥有特殊的窗口表现,此时,页面级别的 .json 配置文件就可以实现这种需求
注意:当页面配置与全局配置冲突时,根据就近原则,最终的效果以页面配置为准
思考
❓ jQuery 中如何发起网络请求 ? 同时我们思考什么是跨域?小程序中是否存在跨域 ?
$.ajax({
url: ‘xxx’,
method: ‘GET’,
success: function (data) {
console.log(data)
}
})
出于安全性方面的考虑,小程序官方对数据接口的请求做出了如下两个限制:
需求描述:假设在自己的微信小程序中,希望请求 https://www.escook.cn/ 域名下的接口
配置步骤:\登录微信小程序\管理后台 → 开发 → 开发设置 → 服务器域名 → 修改 request 合法域名
修改时需要注意事项:
调用微信小程序提供的 wx.request() 方法,可以发起 GET 数据请求
Page({
getHandler(){
wx.request({
url:'https://www.escook.cn/api/get',
method:'GET', // 请求方式
data:{ // 请求参数
id:1
},
success:(data)=>{ // 请求成功的回调函数
const { data:res } = data
console.log(res)
}
})
}
})
调用微信小程序提供的 wx.request() 方法,可以发起 POST 数据请求
Page({
postHandler(){
wx.request({
url:'https://www.escook.cn/api/post',
method:'POST', // 请求方式
data:{ // 请求参数
id:1
},
success:(data)=>{ // 请求成功的回调函数
const { data:res } = data
console.log(res)
}
})
}
})
在很多情况下,我们需要在页面刚加载的时候,自动请求一些初始化的数据。此时需要在页面的 onload 事件中调用获取数据的函数
onLoad: function(options){
this.postHandler()
}
如果后端程序员 仅仅提供了 http 协议的接口、暂时没有提供 https 协议的接口,此时为了不耽误开发的进度,我们需要在微信开发者工具中,临时开启 [开发环境不校验请求域名、TLS 版本及 HTTPS 证书」 选项,跳过服务器域名的校验。此时,在微信开发者工具中及手机开启调试模式时,不会进行服务器域名的校验。
注意:在服务器域名配置成功后,建议开发者关闭此选项进行开发,并在各平台下进行测试,以确认服务器域名配置正确。
1、新建项目并梳理项目结构
2、配置导航栏效果
app.json
里面的配置
"window": {
"backgroundTextStyle": "light",
"navigationBarBackgroundColor": "#2b4b6b",
"navigationBarTitleText": "本地生活",
"navigationBarTextStyle": "white"
}
3、配置 tabBar
app.json
里面配置
"tabBar": {
"selectedColor": "#ed523c",
"backgroundColor": "#fff",
"list": [
{
"pagePath": "pages/home/home",
"text": "主页",
"iconPath": "/images/tabs/home.png",
"selectedIconPath": "/images/tabs/home-active.png"
},
{
"pagePath": "pages/message/message",
"text": "消息",
"iconPath": "/images/tabs/message.png",
"selectedIconPath": "/images/tabs/message-active.png"
},
{
"pagePath": "pages/contact/contact",
"text": "联系我们",
"iconPath": "/images/tabs/contact.png",
"selectedIconPath": "/images/tabs/contact-active.png"
}
]
}
4、实现轮播图效果
home.js
// pages/home/home.js
Page({
/**
* 页面的初始数据
*/
data: {
// 1. 创建存放轮播图数据的列表
swiperList:[]
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
// 3. 调用获取轮播图数据方法
this.getSwiperList()
},
// 2. 定义获取轮播图数据的方法
getSwiperList () {
wx.request({
url: 'https://www.escook.cn/slides',
method:'GET',
success: res=>{
this.setData({
swiperList:res.data
})
}
})
}
})
home.wxml
绘制结构
<swiper indicator-dots circular>
<swiper-item wx:for="{{ swiperList }}" wx:key="id">
<image src="{{ item.image }}">image>
swiper-item>
swiper>
home.wxss
绘制样式
swiper{
height: 350rpx;
}
swiper-item image{
width: 100%;
height: 100%;
}
5、获取九宫格数据
home.js
// pages/home/home.js
Page({
/**
* 页面的初始数据
*/
data: {
// 创建存放轮播图数据的列表
swiperList:[],
// 存放九宫格数据的列表
gridList:[]
},
/**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
// 调用获取轮播图数据方法
this.getSwiperList()
// 调用获取宫格数据的方法
this.getGridList()
},
// 定义获取轮播图数据的方法
getSwiperList () {
wx.request({
url: 'https://www.escook.cn/slides',
method:'GET',
success: res=>{
this.setData({
swiperList:res.data
})
}
})
},
// 定义获取九宫格数据的方法
getGridList () {
wx.request({
url: 'https://www.escook.cn/categories',
method:'GET',
success: res=>{
this.setData({
gridList: res.data
})
}
})
}
})
home.wxml
绘制结构
<swiper indicator-dots circular>
<swiper-item wx:for="{{ swiperList }}" wx:key="id">
<image src="{{ item.image }}">image>
swiper-item>
swiper>
<view class="grid-list">
<view class="grid-item" wx:for="{{ gridList }}" wx:key="id">
<image src="{{ item.icon }}">image>
<text>{{ item.name }}text>
view>
view>
home.wxss
绘制样式
.grid-list{
display: flex;
flex-wrap: wrap;
border-top: 1px solid #efefef;
border-left:1px solid #efefef;
}
.grid-item{
width: 32.333%;
height: 200rpx;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
border-right: 1px solid #efefef;
border-bottom: 1px solid #efefef;
box-sizing: border-box;
flex-grow: 1;
}
.grid-item image{
width: 60rpx;
height: 60rpx;
}
.grid-item text{
font-size: 24rpx;
margin-top: 10rpx;
}
6、实现 图片布局
<swiper indicator-dots circular>
<swiper-item wx:for="{{ swiperList }}" wx:key="id">
<image src="{{ item.image }}">image>
swiper-item>
swiper>
<view class="grid-list">
<view class="grid-item" wx:for="{{ gridList }}" wx:key="id">
<image src="{{ item.icon }}">image>
<text>{{ item.name }}text>
view>
view>
<view class="img-box">
<image src="/images/link-01.png" mode="widthFix">image>
<image src="/images/link-02.png" mode="widthFix">image>
view>
.img-box{
display: flex;
justify-content: space-around;
padding: 20rpx 10rpx;
}
.img-box image{
width: 45%;
}