WeCaht小程序开发:基础笔记(一)

一、生命周期

1、什么是生命周期?

小程序启动,表示生命周期的开始。
小程序关闭,表示生命周期的结束。
中间小程序运行的过程,就是小程序的生命周期。

2、生命周期的分类

在小程序中,声明中求分为两类,分别是:
应用生命周期,特指小程序从启动-运行-销毁的过程。
页面生命周期,特指小程序中,每个页面的加载-渲染-销毁的过程。

3、什么是生命周期函数

生命周期函数:是由小程序框架提供的内置函数,会伴随着生命周期,自动按次序执行。
生命周期函数的作用:允许程序员咋特定的时间点,执行某些二特定的操作。
注意:生命周期强调的是时间段,生命周期函数强调的是时间点。

4、生命周期函数的分类

两类:
	应用的生命周期函数
		特指小程序从启动-运行-销毁期间依次调用的那些函数。
	页面的生命周期函数
		特指小程序中,每个页面从加载-渲染-销毁期间依次调用的那些函数。

5、应用的生命周期函数

小程序的应用生命周期函数需要在app.js中进行声明。

6、页面的生命周期函数

小程序的页面生命周期函数需要在页面的.js文件中进行声明。

二、什么时rpx尺寸单位

rpx(responsive pixel)是微信小程序独有的,用来解决屏幕适配的尺寸单位。

三、小程序中的.js文件

一个项目仅仅提供界面展示是不够的,在小程序中,我们通过.js文件来处理用户的操作。例如:
响应用户的点击、获取用户的位置等等。

小程序中.js文件的分类:
1、app.js:
是整个小程序项目的入口文件,通过调用App()函数来启动整个小程序
2、页面的.js文件:
是页面的入口文件,通过调用Page()函数来创建并运行页面
3、普通的.js文件:
是普通的功能模块文件,用来封装公共的函数或属性供页面使用。

四、什么是tabBar

tabBar是移动端应用常见的页面效果,用于实现多页面的快速切换,小程序中通常将其分为:
	*底部tabBar
	*顶部tabBar
注意:
*tabBar中只能配置最少2个、最多5个tab页签
*当渲染顶部tabBar时,不显示icon,只显示文本

tabBar的6个组成成分:

backGroundColor:tabBar的背景色
selectedIconPath:选中时图片路径
borderStyle:tabBar上边框的颜色
iconPath:未选中时的图片路径
selectedColor:tab上文字选中时的颜色
color:tab上文字(默认)未选中时的颜色

五、WXML

WXML(WeiXin Markup Language)是小程序框架设计的一套标签语言,用来构建小程序首页的结构,其作用类似于网页开发中的HTML。

WXML与HTML的区别:
1、标签名不同
HTML(div,span,img,a)
WXML(view,text,image,navigator)
2、属性节点不同

<a href="#">超链接</a>
	<navigator url="/pages/home/home"></navigator>
3、提供了类似于Vue中的模板语法
	数据绑定
	列表渲染
	条件渲染

六、WXSS

WXSS(WeiXin Style Sheets)是一套样式语言,用于描述WXML的组件样式,类似于网页开发中的CSS。

WXSS与CSS的区别:
1、新增了RPX尺寸单位

CSS中需要手动进行像素单位换算,列如rem WXSS在底层支持新的尺寸单位rpx,在不同大小屏幕上小程序会自动进行换算

2、提供了全局的样式和布局样式

项目根目录中的app、wxss会作用于所有小程序页面 局部页面的wxss样式仅对当前页面生效

3、WXSS仅支持部分CSS选择器

.class和#id
element 并集选择器
后代选择器
::after和::before等伪类选择器

wxss和css的关系:

WXSS具有CSS大部分特性,同时,WXSS还对CSS进行了扩充以及修改,以适应微信小程序的开发。

与CSS相比,WXSS扩展的特性有:

  rpx尺寸单位 		@import样式导入

七、声明式导航

声明式导航:
1、在页面上声明一个导航组件。
2、通过点击组件实现页面跳转。
a、导航到tabBar页面:
tabBar页面指的是被配置为tabBar的页面。
在使用组件跳转到指定的tabBar页面时,需要指定url属性和open-type属性,其中:

*url表示要跳转的页面的地址,必须以/开头 *open-type表示跳转的方式,必须为switchTab

示例代码:

<navigator url="/pages/message/message" open-type="switchTab">导航到消息页面</navigator>

b、跳转到非tabBar页面
非tabBar页面指的是没有被配置为tabBar的页面。
在使用组件跳转到普通的非tabBar页面时,则需要指定url属性和open-type属性,其中:

*url表示要跳转的页面的地址,必须以/开头。
*open-type表示要跳转的方式,必须为navigator

示例代码:

在这里插入代码片<navigator url="/pages/info/info" open-type="navigator">导航到info页面</navigator>

八、事件绑定

1、什么是事件?

事件是渲染层到逻辑层的通讯方式。
通过事件可以将用户在渲染层产生的行为,反馈到逻辑层进行业务的处理。

2、小程序中常用的事件

tap:绑定方式(bindtap或bind:tap)
事件描述:手指触摸后马上离开,类似于HTML中的click事件。

input:绑定方式(bindinput或bind:input)
事件描述:文本框的输入事件。

change:绑定方式(bindchange或bind:change
事件描述:状态改变时触发。

3、事件对象的属性列表

当事件回调触发的时候,会收到一个事件对象的event,它的详细属性如下表所示:

属性 类型 说明
type String 事件类型
timeStamp integer 页面打开到触发事件所经过的毫秒数
target Object 触发事件的组件的一些属性值集合
currentTarget Object 当前组件的一些属性值集合
detail Object 额外的信息
touches Array 触发事件,当前停留在屏幕中的触发点信息的数组
changetouches Array 触发事件,当前变化的触发点信息的数组

4、target和currentTarget的区别

target是触发该事件的源头组件,而currentTarget则是当前事件所绑定的组件。
点击内部的按钮时,点击事件以冒泡的方式由内向外扩散,也会触发外层view的tap事件处理函数。
此时,对于外层的view来说:

1、e.target指向的是触发事件的源头组件,因此,e.target是内部的按钮组件。
2、e.currentTarget指向的是当前正在触发事件的那个组件,因此,e.currentTarget是当前的view组件。

5、bindtap的语法格式

在小程序中,不存在HTML中的onclick鼠标点击事件,而是通过tap事件来响应用户的触发事件

1、通过bindtap,可以为组件绑定tap触发事件,语法如下: 按钮
2、在页面的.js文件中定义对应的事件处理函数,事件参数通过形参event(一般简写成e)来接收。

6、在事件处理函数中为data中的数值赋值

通过调用this.setData(dataObject)方法,可以给页面data中的数据重新赋值。

7、事件传参

小程序的事件传参比较特殊:

a、不能以绑定事件的同时为事件处理函数传递参数。例如: 事件传参
因为小程序会把bindtap的属性值,同意当作时间名称来处理,相当于要调用一个名称为 btnHandler(123)的事件处理函数。
b、可以为组件提供data-自定义属性传参,其中代表的时参数的名字,例如:

最终:
1、info会被解析为参数的名字。
2、数值2会解析为参数的值。
3、在时间处理函数中,通过event.target.dataset参数名即可获得到具体参数值的值,
例如:
btnHandler(event){
//data是一个对象,包含所有通过data-*传递过的参数项
console.log(event,target.dataset)
//通过dataset可以访问到具体参数的值。
console.log(event.target.dataset.info)
}

8、bindinput的语法格式

在小程序中,通过input事件来响应文本框的输入事件,语法如下:

1、通过bindinput,可以为文本绑定输入事件:
2、在页面的.js文件中定义事件处理函数: inputHandler(e){ //e.detail.value是变化过后,文本框最新的值
console.log(e.datail.value) }

9、实现文本框和data之间的数据同步

实现步骤:

1、定义数据
2、渲染结构
3、美化样式
4、绑定input事件处理函数

九、条件渲染

1、wx:if

在小程序中,使用wx:if="{{condition}}"来判断是否需要渲染该代码块:

<view wx:if="{{condition}}">True</view>

也可以用wx:elif和wx:else来添加else判断。

2、结合使用wx:if

如果要一次性控制多个组件的展示与隐藏,可以使用标签将多个view包裹
在一起,注意block只是个包裹组件不渲染。

3、hidden

在小程序中,直接使用hidden="{{condition}}"也能控制元素的显示与隐藏。

4、wx:if与hidden对比

a、运行方式不同:
	1、wx:if以动态创建和移除元素的方式,控制元素的展示与隐藏。
	2、hidden以切换样式的方式(display:none/block),控制元素的显示与隐藏。
b、使用建议:
	1、频繁切换时,使用hidden
	2、控制条件比较复杂,使用wx:if。因为hidden只有隐藏或者显示两个选项。

你可能感兴趣的:(微信小程序,微信小程序)