微信小程序入门教程之三:脚本编程
今天,接着往下讲,教大家为小程序加入 JavaScript 脚本,做出动态效果,以及如何跟用户互动。学会了脚本,就能做出复杂的页面了。
本篇的难度要大于前两篇,如果觉得不好理解,可以先跟着例子,动手做一遍,然后再读文字说明,可能就容易理解了。
所有示例的完整代码,都可以从 GitHub 的代码仓库下载。
一、数据绑定
前面的所有示例,小程序的页面都是写死的,也就是页面内容不会变。但是,页面数据其实可以通过脚本传入,通过脚本改变页面,实现动态效果。
小程序提供了一种特别的方法,让页面可以更方便地使用脚本数据,叫做"数据绑定"(data binding)。
所谓"数据绑定",指的是脚本里面的某些数据,会自动成为页面可以读取的全局变量,两者会同步变动。也就是说,脚本里面修改这个变量的值,页面会随之变化;反过来,页面上修改了这段内容,对应的脚本变量也会随之变化。这也叫做 MVVM 模式。
下面看一个例子。打开home.js
文件,改成下面这样。
Page({
data: {
name: '张三'
}
});
上面代码中,Page()
方法的配置对象有一个data
属性。这个属性的值也是一个对象,有一个name
属性。数据绑定机制规定,data
对象的所有属性,自动成为当前页面可以读取的全局变量。也就是说,home
页面可以自动读取name
变量。
接着,修改home.wxml
文件,加入name
变量。
<view>
<text class="title">hello {{name}}</text>
</view>
上面代码中,name
变量写在{{...}}
里面。这是小程序特有的语法,两重大括号表示,内部不是文本,而是 JavaScript 代码,它的执行结果会写入页面。因此,{{name}}
表示读取全局变量name
的值,将这个值写入网页。
注意,变量名区分大小写,name
和Name
是两个不同的变量名。
开发者工具导入项目代码,页面渲染结果如下。
可以看到,name
变量已经自动替换成了变量值"张三"。
这个示例的完整代码,可以查看代码仓库。
页面和脚本对于变量name
是数据绑定关系,无论哪一方改变了name
的值,另一方也会自动跟着改变。后面讲解到事件时,会有双方联动的例子。
二、全局数据
数据绑定只对当前页面有效,如果某些数据要在多个页面共享,就需要写到全局配置对象里面。
打开app.js
,改写如下。
App({
globalData: {
now: (new Date()).toLocaleString()
}
});
上面代码中,App()
方法的参数配置对象有一个globalData
属性,这个属性就是我们要在多个页面之间分享的值。事实上,配置对象的任何一个属性都可以共享,这里起名为globalData
只是为了便于识别。
然后,打开home.js
,改成下面的内容,在页面脚本里面获取全局对象。
const app = getApp(); Page({
data: {
now: app.globalData.now
}
});
上面代码中,getApp()
函数是小程序原生提供的函数方法,用于从页面获取 App 实例对象。拿到实例对象以后,就能从它上面拿到全局配置对象的globalData
属性,从而把app.globalData.now
赋值给页面脚本的now
属性,进而通过数据绑定机制,变成页面的全局变量now
。
最后,修改一下页面代码home.wxml
。
<view>
<text class="title">现在是 {{now}}</text>
</view>
开发者工具导入项目代码,页面渲染结果如下。
可以看到,页面读到了全局配置对象app.js
里面的数据。
这个示例的完整代码,可以查看代码仓库。
三、事件
事件是小程序跟用户互动的主要手段。小程序通过接收各种用户事件,执行回调函数,做出反应。
小程序的常见事件有下面这些。
tap
:触摸后马上离开。longpress
:触摸后,超过 350ms 再离开。如果指定了该事件的回调函数并触发了该事件,tap
事件将不被触发。touchstart
:触摸开始。touchmove
:触摸后移动。touchcancel
:触摸动作被打断,如来电提醒,弹窗等。touchend
:触摸结束。
上面这些事件,在传播上分成两个阶段:先是捕获阶段(由上层元素向下层元素传播),然后是冒泡阶段(由下层元素向上层元素传播)。所以,同一个事件在同一个元素上面其实会触发两次:捕获阶段一次,冒泡阶段一次。详细的介绍,请参考我写的事件模型解释。
小程序允许页面元素,通过属性指定各种事件的回调函数,并且还能够指定是哪个阶段触发回调函数。具体方法是为事件属性名加上不同的前缀。小程序提供四种前缀。
capture-bind
:捕获阶段触发。capture-catch
:捕获阶段触发,并中断事件,不再向下传播,即中断捕获阶段,并取消随后的冒泡阶段。bind
:冒泡阶段触发。catch
:冒泡阶段触发,并取消事件进一步向上冒泡。
下面通过一个例子,来看如何为事件指定回调函数。打开home.wxml
文件,改成下面的代码。
<view>
<text class="title">hello {{name}}</text>
<button bind:tap="buttonHandler">点击</button>
</view>
上面代码中,我们为页面加上了一个按钮,并为这个按钮指定了触摸事件(tap
)的回调函数buttonHandler
,bind:
前缀表示这个回调函数会在冒泡阶段触发(前缀里面的冒号可以省略,即写成bindtap
也可以)。
回调函数必须在页面脚本中定义。打开home.js
文件,改成下面的代码。
Page({
data: {
name: '张三'
},
buttonHandler(event) {
this.setData({
name: '李四'
});
}
});
上面代码中,Page()
方法的参数配置对象里面,定义了buttonHandler()
,这就是<button>
元素的回调函数。它有几个地方需要注意。
(1)事件回调函数的参数是事件对象event
,可以从它上面获取事件信息,比如事件类型、发生时间、发生节点、当前节点等等。
(2)事件回调函数内部的this
,指向页面实例。
(3)页面实例的this.setData()
方法,可以更改配置对象的data
属性,进而通过数据绑定机制,导致页面上的全局变量发生变化。
开发者工具导入项目代码,点击按钮后,页面渲染结果如下。
可以看到,点击按钮以后,页面的文字从"hello 张三"变成了"hello 李四"。
这个示例的完整代码,可以查看代码仓库。
这里要强调一下,修改页面配置对象的data
属性时,不要直接修改this.data
,这不仅无法触发事件绑定机制去变更页面,还会造成数据不一致,所以一定要通过this.setData()
去修改。this.setData()
是一个很重要的方法,有很多细节,详细介绍可以读一下官方文档。
四、动态提示 Toast
小程序提供了很多组件和方法,用来增强互动效果。比如,每次操作后,都显示一个动态提示,告诉用户操作的结果,这种效果叫做 Toast。
打开home.js
文件,为this.setData()
加上第二个参数。
Page({
data: {
name: '张三'
},
buttonHandler(event) {
this.setData({
name: '李四'
}, function () {
wx.showToast({
title: '操作完成',
duration: 700
});
}),
}
});
上面代码中,this.setData()
方法加入了第二个参数,这是一个函数,它会在页面变更完毕后(即this.setData()
执行完)自动调用。
这个参数函数内部,调用了wx.showToast()
方法,wx
是小程序提供的原生对象,所有客户端 API 都定义在这个对象上面,wx.showToast()
会展示微信内置的动态提示框,它的参数对象的title
属性指定提示内容,duration
属性指定提示框的展示时间,单位为毫秒。
开发者工具导入项目代码,点击按钮后,页面渲染结果如下。
过了700毫秒,提示框就会自动消失。
这个示例的完整代码,可以查看代码仓库。
五、对话框 Modal
下面,我们再用小程序提供的wx.showModal()
方法,制作一个对话框,即用户可以选择"确定"或"取消"。
打开home.js
文件,修改如下。
Page({
data: {
name: '张三'
},
buttonHandler(event) {
const that = this;
wx.showModal({
title: '操作确认',
content: '你确认要修改吗?',
success (res) {
if (res.confirm) {
that.setData({
name: '李四'
}, function () {
wx.showToast({
title: '操作完成',
duration: 700
});
});
} else if (res.cancel) {
console.log('用户点击取消');
}
}
});
}
});
上面代码中,用户点击按钮以后,回调函数buttonHandler()
里面会调用wx.showModal()
方法,显示一个对话框,效果如下。
wx.showModal()
方法的参数是一个配置对象。title
属性表示对话框的标题(本例为"操作确认"),content
属性表示对话框的内容(本例为"你确认要修改吗?"),success
属性指定对话框成功显示后的回调函数,fail
属性指定显示失败时的回调函数。
success
回调函数里面,需要判断一下用户到底点击的是哪一个按钮。如果参数对象的confirm
属性为true
,点击的就是"确定"按钮,cancel
属性为true
,点击的就是"取消"按钮。
这个例子中,用户点击"取消"按钮后,对话框会消失,控制台会输出一行提示信息。点击"确定"按钮后,对话框也会消失,并且还会去调用that.setData()
那些逻辑。
注意,上面代码写的是that.setData()
,而不是this.setData()
。这是因为setData()
方法定义在页面实例上面,但是由于success()
回调函数不是直接定义在Page()
的配置对象下面,this
不会指向页面实例,导致this.setData()
会报错。解决方法就是在buttonHandler()
的开头,将this
赋值给变量that
,然后在success()
回调函数里面使用that.setData()
去调用。关于this
更详细的解释,可以参考这篇教程。
这个示例的完整代码,可以查看代码仓库。
今天的教程就到这里,对于初学者来说,已经讲了很多东西,可能需要慢慢消化。如果对网页开发和 JavaScript 语言不熟悉,你也许会觉得不容易完全理解,不用担心,初学者只需要知道加入脚本的方法,以及脚本可以达到的效果就可以了,后面做到实际的项目,慢慢就会加深理解。
有了脚本以后,就可以通过小程序 API,去调用微信的各种内置能力。下一篇教程将重点讲解如何使用小程序 API。
(完)
微信小程序入门教程之三:脚本编程的更多相关文章
- 从零开始的微信小程序入门教程(一)
之前说要和同事一起开发个微信小程序项目,现在也在界面设计,功能定位等需求上开始实施了.所以在还未正式写项目前,打算在空闲时间学习下小程序.本意是在学习过程中结合实践整理出一个较为入门且不是很厚的教程, ...
- 微信小程序入门教程之四:API 使用
今天是这个系列教程的最后一篇. 上一篇教程介绍了,小程序页面如何使用 JavaScript 脚本.有了脚本以后,就可以调用微信提供的各种能力(即微信 API),从而做出千变万化的页面.本篇就介绍怎么使 ...
- 微信小程序入门教程
首先请看demo 很简单的静态js就可以实现一款小程序开发. js.json.html.css四个核心文件 序言 开始开发应用号之前,先看看官方公布的「小程序」教程吧!(以下内容来自微信官方公布的「小 ...
- 微信小程序入门教程之一:初次上手
微信是中国使用量最大的手机 App 之一,日活跃用户超过3亿,月活跃用户超过11亿(2019年底统计),市场极大. 2017年,微信正式推出了小程序,允许外部开发者在微信内部运行自己的代码,开展业务. ...
- 开发微信小程序入门教程,含破解工具
2016年09月21日晚 微信发不了微信“小程序”的内测版,一时间整个互联网都炸了锅.个大新闻.论坛都在讨论这个事情. 作为互联网的一猿,我们怎能不紧跟时代的脚步.于是第二天上午也对微信发布的“小程序 ...
- 微信小程序入门教程(一)API接口数据记录
今天测试用小程序调用API接口,发现有些数据打印都是对象,怎么全部打印详细点来 小程序代码: httpsearch: function (name, offset, type, cb) { wx.re ...
- 微信小程序入门与实战(最新完整版)教程
微信小程序入门与实战(最新完整版) 如图地址:下载地址在底部 |- 第1章 什么是微信小程序? - 0 B |- 第2章 小程序环境搭建与开发工具介绍 - 0 B |- 第3章 从一个简单的“欢迎“页 ...
- 微信小程序入门正确姿势(一)
[未经作者本人同意,请勿以任何形式转载] >>>前言 这是 [认真学编程] 系列的 第4篇 文章(微信小程序入门系列),欢迎点赞分享.写留言,这些都是对我最好的支持. 本系列适合有一 ...
- 天河微信小程序入门《四》:融会贯通,form表单提交数据库
天河在阔别了十几天之后终于又回来了.其实这篇文章里的demo是接着(天河微信小程序入门<三>)后面就做了的,但是因为最近在做别的项目,所以就偷懒没有发出来.放到今天来看,从前台提交数据到数 ...
随机推荐
- ApacheShiro反序列化远程代码执行 漏洞处理
Shiro对rememberMe的cookie做了加密处理,shiro在CookieRememberMeManaer类中将cookierememberMe字段内容分别进行序列化.AES加密.Base6 ...
- 【LeetCode】171. Excel Sheet Column Number 解题报告(Java & Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目大意 解题方法 Java解法 Python解法 日期 [LeetCode] 题 ...
- 【LeetCode】966. Vowel Spellchecker 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 字典 日期 题目地址:https://leetcod ...
- 【LeetCode】743. Network Delay Time 解题报告(Python)
[LeetCode]743. Network Delay Time 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuemingzhu 个人博客: ht ...
- 【LeetCode】289. Game of Life 解题报告(Python)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- Docker 与 K8S学习笔记(五)—— 容器的操作(上篇)
上一篇我们介绍了Dockerfile的基本编写方法,这一节我们来看看Docker容器的常用操作. 一.容器的运行方式 容器有两种运行方式,即daemon形式运行与非daemon形式运行,通俗地讲就是长 ...
- EBGAN
目录 概 主要内容 Zhao J., Mathieu M. & LeCun Y. Energy-based generative adversarial networks. ICLR, 201 ...
- Vue.js高效前端开发 • 【Vue基本指令】
全部章节 >>>> 文章目录 一.Vue模板语法 1.插值 2.表达式 3.指令概述 4.实践练习 二.Vue绑定类样式和内联样式 1.Vue绑定类样式 2.Vue绑定内联样式 ...
- JavaWeb项目作业 Market商品管理系统
目录 一.语言和环境 二.实现功能 三.数据库设计 四.实现代码 一.语言和环境 实现语言:Java语言. 环境要求:MyEclipse(Eclipse)+MySQL. 实现方式:JBDC.jsp/s ...
- 关于一类容斥原理设计 dp 状态的探讨
写在前面 为什么要写?因为自己学不明白希望日后能掌握. 大体思路大概是 设计一个容斥的方案,并使其贡献可以便于计算. 得出 dp 状态,然后优化以得出答案. 下列所有类似 \([l,r]\) 这样的都 ...