微信小程序学习笔记二

1. 小程序特点概述

  1. 没有DOM
  2. 组件化开发: 具备特定功能效果的代码集合
  3. 体积小, 单个压缩包体积不能大于2M, 否则无法上线
  4. 小程序的四个重要的文件

    *js

    *.wxml ---> view 结构 ---> html

    *wxss ---> view样式 ---> css

    *.json --->view 数据 ---> json文件
  5. 小程序适配方案: rpx (responsive pixel 响应式像素单位)

    小程序适配单位 px

    规定任何屏幕下宽度为 750px

    小程序会根据屏幕的宽度不同自动计算rpx 值的大小

    Iphone6下 : 1rpx = 1物理像素 = 0.5px

2. wxml语法


2.1 数据绑定

2.1.1 初始化数据

  1. 页面.jsdata选项中定义初始化数据
// pages/index/index.js
Page({
/**
* 页面的初始数据
*/
data: {
message:"hello world"
},
})

在调试器中的 AppData中可以查看当前文件的数据


2.1.2 使用数据

  1. 模板结构中使用双大括号(插值表达式) {{mssage}}
  2. 注意事项: 小程序中为单项数据流 model ---> view



    点开模拟器就可以看到页面解析后的样子了


2.1.3 修改数据

  1. this.setData( { DATA_NAME: "NEW_VALUE"}, callback)
  2. 特点:

    2.1 同步修改: this.data值被同步修改

    2.2 异步更新: 异步将setData函数用于将数据从逻辑层发送到视图层(异步)
// pages/index/index.js
Page({
/**
* 页面的初始数据
*/
data: {
message:"hello world"
}, /**
* 生命周期函数--监听页面加载
*/
onLoad: function (options) {
console.log('页面加载完成'); // 修改message的状态,语法: this.setData
console.log(this); // this 代表当前页面的实例对象
this.setData({message:'new Hello World'},function () {
console.log('数据更新完成')
})
}
})



  • 在上面代码中我们知道了, setData修改数据的操作, 在自身所带的钩子函数中是同步的, 下面我们来测试一下在非自身的钩子函数中修改数据是否同步
  • 代码如下:
onLoad: function (options) {
// 这里我们定义了一个定时器, 延时两秒执行, 运行一下看在模拟器中看效果![请添加图片描述](https://img-blog.csdnimg.cn/28b629180a6c414ab23c802cc5571b9b.gif) setTimeout(() => {
this.setData({ message: 'new Hello World' }, function () {
console.log('数据更新完成')
})
}, 2000);
},



由此我们可以得出, 小程序的数据修改,在非自身的钩子函数中也是同步的


2.2 事件绑定

2.2.1 事件分类

事件分为冒泡事件和非冒泡事件:

  • 冒泡事件:当一个组件上的事件被触发后,该事件会向父节点传递。
  • 非冒泡事件:当一个组件上的事件被触发后,该事件不会向父节点传递。
    • 非冒泡事件:表单事件和自定义事件通常是非冒泡事件

事件列表

类型 触发条件 最低版本
touchstart 手指触摸动作开始 -
touchmove 手指触摸后移动 -
touchcncel 手指触摸动作被打断,如来电提醒,弹窗等 -
touchend 手指触摸动作结束 -
tap 手指触摸后马上离开 -
longpress 手指触摸后,超过350ms再离开, 如果指定了事件回调函数并触发了这个事件, tap事件将不被触发 1.5.0
longtap 手指触摸后, 超过350ms再离开 (推荐使用longpress事件代替) -
transitionend 会在 WXSS transitionwx.createAnimation动画结束后触发 -
animationstart 会在一个WXSS animation动画开始时触发 -
animationiteration 会在一个WXSS animation一次迭代结束时触发
animationend 会在一个WXSS animation动画完成时触发 -
touchforcechange 在支持 3D Touch的iPhone设备, 重按时会触发 1.9.90

2.2.2 绑定事件

  • bind绑定: 事件绑定不会阻止冒泡事件向上冒泡

    演示: 分别在 index.wxmlindex.js定义以下代码
<view class="goStudy" bindtap="clickParent">
<text catchtap="bindtap">{{message}}</text>
</view>
  clickParent() {
console.log('clickParent()');
},
clickChild() {
console.log('clickChild()');
},
  • 点击text标签之后我们查看调试器中信息, 可以看到外层的父元素的tap事件也被触发了

  • catch绑定: 事件绑定可以阻止冒泡事件向上冒泡

  • 演示: 我们将index.wxml代码修改如下

<view class="goStudy" bindtap="clickParent">
<text catchtap="bindtap">{{message}}</text>
</view>
  • 点击text标签之后我们查看调试器中信息

  • 可以看到只打印了一个clickChild(), 说明我们的默认冒泡事件被阻止了


2.2.3 向事件对象传参

  • 在小程序开发的时候,有时候需要在点击事件触发之后拿到一个参数做为使用,小程序不像 Vue 可以直接点击事件中放参数,而小程序它只能通过自定义属性进行绑定参数使用。
  1. 语法: data-KEY=VALUE

    1.1 在index.wxml中这样写
 <text catchtap="clickChild" data-msg="传递的hello world">{{message}}</text>
  1. 获取: event.target.dataset.key || event.currentTarget.dataset.key
 clickChild(e) {
console.log('clickChild()');
console.log(e.currentTarget.dataset.msg);
let newMsg = e.currentTarget.dataset.msg;
this.setData({message:newMsg});
},

  1. Event.targetevent.currenTarget的区别

    3.1 Event.target是触发事件的对象, 但不一定是绑定事件的对象, 如: 事件委托, 冒泡

    3.2 currentTarget触发事件的对象一定是绑定事件的对象, 没有事件委托

微信小程序学习笔记二 数据绑定 + 事件绑定的更多相关文章

  1. 微信小程序学习笔记二 列表渲染 + 条件渲染

    1. 列表渲染 1.1 wx:for 在组件上使用wx:for控制属性绑定一个数组, 即可使用数组中各项的数据重复渲染该组件 默认数组的当前项的下标变量名默认为 index, 数组当前项的变量名默认为 ...

  2. 【微信小程序学习笔记】入门与了解

    [微信小程序学习笔记(一)] IDE 下载安装 下载地址 官方工具:https://mp.weixin.qq.com/debug/w … tml?t=1476434678461 下载可执行文件后,可按 ...

  3. 微信小程序学习笔记一 小程序介绍 & 前置知识

    微信小程序学习笔记一 1. 什么是小程序? 2017年度百度百科十大热词之一 微信小程序, 简称小程序, 英文名 Mini Program, 是一种不需要下载安装即可使用的应用 ( 张小龙对其的定义是 ...

  4. 微信小程序学习笔记(二)--框架-全局及页面配置

    描述和功能 框架提供了自己的视图层描述语言 WXML 和 WXSS,以及基于 JavaScript 的逻辑层框架,并在视图层与逻辑层间提供了数据传输和事件系统,让开发者能够专注于数据与逻辑. 响应的数 ...

  5. 微信小程序学习笔记(一)--创建微信小程序

    一.创建小程序 1.申请帐号.安装及创建小程序,请参照官方文档里面的操作 https://developers.weixin.qq.com/miniprogram/dev/. 小程序在创建的时候会要求 ...

  6. 微信小程序学习笔记(阶段一)

    一阶段学习过程: (一)看官方文档的简易教程:https://mp.weixin.qq.com/debug/wxadoc/dev/ (二)看小码哥视频:https://chuanke.baidu.co ...

  7. 微信小程序学习笔记(3)--------框架之配置

    我们使用app.json文件来对微信小程序进行全局配置,决定页面文件的路径.窗口表现.设置网络超时时间.设置多 tab 等. app.json 配置项列表 属性 类型 必填 描述 pages Stri ...

  8. 微信小程序学习笔记以及VUE比较

    之前只是注册了一下微信小程序AppID,随便玩了玩HelloWorld!(项目起手式),但是最近看微信小程序/小游戏,崛起之势不可阻挡.小程序我来了!(果然,一入前端深似海啊啊啊啊啊~) 编辑器: S ...

  9. 微信小程序学习笔记1--小程序的代码构成

    最近打算学习一下微信小程序,看了微信公众平台的文档感觉还比较简单,就从这个方向重新找回学习的状态吧: 1.先了解一下小程序的代码构成: 创建项目后会看到四种后缀的文件: .json 后缀的 JSON ...

随机推荐

  1. Jmeter任在运行,线程数上不去

    问题 jmeter在运行,但是线程数上不去(本来模型设计了100个总线程,但运行时线程只能上到5,根据图上观察总共也只能运行5个线程) 之前更新了random csv插件 解决办法 查看jmeter. ...

  2. Discuz! X3.4 邮件设置 使用qq邮箱发邮件

    1. 在qq邮箱->设置中,获取授权码 2. 在discuz后台配置基础信息 3.  在服务器的防火墙中添加规则,允许访问465端口

  3. 利用 PGO 提升 .NET 程序性能

    引子 .NET 6 开始初步引入 PGO.PGO 即 Profile Guided Optimization,通过收集运行时信息来指导 JIT 如何优化代码,相比以前没有 PGO 时可以做更多以前难以 ...

  4. 程序向informix数据库插入text类型的中文乱码问题

    部署应用的Linux服务器的编码格式为utf-8.但是数据库的编码格式为Gbk.所以导致的乱码.但是其他类型的数据中文并不乱码. 通过图片中修改编码格式,可以解决,导致的后果就是tomcat的日志输出 ...

  5. Oracle 对 sql 的处理过程

    当你发出一条 sql 语句交付 Oracle,在执行和获取结果前,Oracle 对此 sql 将进行几个步骤 的处理过程: 1.语法检查(syntax check)   检查此 sql 的拼写是否语法 ...

  6. 当鼠标移入div上时,div的背景色在4s之内渐变为灰色,同时在5s之内顺时针旋转45度,且尺寸缩小一半;当鼠标移走时,再渐变恢复初始样式

    <style> #d1{ width:200px; height:200px; border:1px solid #000; transition:background 4s linear ...

  7. 除了Swagger UI,你还能选择 IGeekFan.AspNetCore.RapiDoc

    IGeekFan.AspNetCore.RapiDoc 看到博客园上的这个文章,说了下Knife4J,评论里有人推荐RapiDoc,放了几个图,看了下,还不错. 心里 便有个想法,借着上次研究 Kni ...

  8. Java代码搭建Dubbo+ZooKeeper 的示例

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  9. Setup a Simple HTTP Proxy Server

    The host 10.21.3.69 has no H3C client, so it can't access the internet. With Tinyproxy, we can setuu ...

  10. MySQL学习06(事务和索引)

    事务 概述 什么是事务 事务就是将一组SQL语句放在同一批次内去执行 如果一个SQL语句出错,则该批次内的所有SQL都将被取消执行 MySQL事务处理只支持InnoDB和BDB数据表类型 事务的ACI ...