【开发课堂】支付宝小程序视图层数据绑定和渲染的能力

简介: 1.数据绑定:使用 Mustache 语法(双大括号)将变量包起来,可以作用于各种场合。  a. 作用于内容  {{message}}  Page({ data: {message: 'Hello alipay!'}}) b.

1.数据绑定:使用 Mustache 语法(双大括号)将变量包起来,可以作用于各种场合。 
 a. 作用于内容 

 {{message}}  
Page({
  data: {
    message: 'Hello alipay!'
  }
})
 

b. 作用于组件属性 

Page({
  data:
{
 id: 0
  }
 })

 c. 作用于控制属性 

Page({
  data: {
    condition: true
  }
})
 

d. 作用于关键字 
 1.true:boolean 类型的 true,代表真值。 
 2.false: boolean 类型的 false,代表假值。 


注意:不要直接写checked="false",其计算结果是一个字符串,转成布尔值类型后代表真值。 

   
 e.  三元运算 

 Hidden 
 

f. 算数运算 

 {{a + b}} + {{c}} + d 
Page({
  data: {
    a: 1,
    b: 2,
    c: 3
  }
})

View 中的内容为3 + 3 + d。 
 g. 逻辑判断 


h. 字符串运算 

{{"hello" + name}}
Page({
   data:{
     name: 'alipay'
   }
 })

 i.  数据路径运算 

{{object.key}} {{array[0]}}
Page({
  data: {
    object: {
      key: 'Hello '
    },
    array: ['alipay']
  }
})

  j. 也可以在 Mustache 内直接进行组合,构成新的对象或者数组 

 
 {{item}} 
Page({
  data: {
    zero: 0
  }
})

  最终组合成数组[0, 1, 2, 3, 4]。 

 k.也可以用扩展运算符...来将一个对象展开 

Page({
  data:
{
 obj1: {
   a: 1,
   b: 2
 },
 obj2: {
   c: 3,
   d: 4
 }
  }
 })


 最终组合成的对象是 {a: 1, b: 2, c: 3, d: 4, e: 5}。 
 l. 如果对象的 key 和 value 相同,也可以间接地表达 

Page({
  data:
{
 foo: 'my-foo',
 bar: 'my-bar'
  }
 })


 最终组合成的对象是 {foo: 'my-foo', bar:'my-bar'}。 
 注意:上述方式可以随意组合,但是如有存在变量名相同的情况,后边的会覆盖前面。 
 2. 条件渲染: 
 (1)a:if 
   在框架中,我们用 a:if="pw_condition" 来判断是否需要渲染该代码块。

 True 

 

 

  也可以用a:elif和a:else来添加一个else块。 

 1  2  3 
 

(2)block a:if 
   因为a:if是一个控制属性,需要将它添加到一个标签上。但是如果我们想一次性判断多个组件标签,我们可以使用一个 
   标签将多个组件包装起来,并在上边使用a:if控制属性。 

view1  view2 
 

 注意: 并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性。 
   
  3.列表渲染: 
  (1)a:for 
  在组件上使用a:for属性可以绑定一个数组,即可使用数组中各项的数据重复渲染该组件。 
  默认数组的当前项的下标变量名默认为index,数组当前项的变量名默认为item。 

  {{index}}: {{item.message}}
Page({
  data: {
    array: [{
      message: 'foo',
    }, {
      message: 'bar'
    }]
  }
 })


  使用a:for-item可以指定数组当前元素的变量名, 
  使用a:for-index可以指定数组当前下标的变量名: 


  {{idx}}: {{itemName.message}}
 

 a:for可以嵌套 
  (2)block a:for 
  类似block a:if,也可以将a:for用在标签上,以渲染一个包含多节点的结构块。 


      {{i}} * {{j}} = {{i * j}}
    
 

(3)a:key 
 如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如 中的输入内容, 的选中状态),需要使用 a:key 来指定列表中项目的唯一的标识符。 
 a:key的值以两种形式提供。 
   o    字符串,代表在for循环的array中item的某个属性。该属性的值需要是列表中唯一的字符串或数字, 且不能动态改变。 
   o    保留关键字*this,代表在for循环中的item本身,这种表示需要item本身是一个唯一的字符串或者数字,比如当数据改变触发渲染层重新渲染的时候,会校正带有key的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。 
   如不提供a:key,会报一个warning, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。 

如有任何不清楚之处,欢迎加入支付宝小程序万人大群咨询
21bece5f7a5abb1fc5b7dc66c469092024975436


目录
相关文章
预约按摩小程序开发,为什么很多上门按摩平台根本招聘不到优秀技师?
上门按摩平台面临招不到优秀技师的问题,主要原因是平台众多,技师选择多样。为解决此问题,平台可引入技师等级制度,根据订单数量和好评率划分高、低等级技师。高等级技师可享受70%-90%的高提成及首页推荐,这不仅能激励技师的积极性,还能帮助平台筛选出优质技师,提升服务质量和口碑,形成良性循环。
|
29天前
|
人工智能 小程序
【一步步开发AI运动小程序】十五、AI运动识别中,如何判断人体站位的远近?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,无需后台支持,具有快速、体验好、易集成等特点。本文介绍如何利用插件判断人体与摄像头的远近,确保人体图像在帧内的比例适中,以优化识别效果。通过`whole`检测规则,分别实现人体过近和过远的判断,并给出相应示例代码。
|
10天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
111 18
|
28天前
|
人工智能 小程序 UED
【一步步开发AI运动小程序】十六、AI运动识别中,如何判断人体站位?
【云智AI运动识别小程序插件】提供人体、运动及姿态检测的AI能力,本地引擎无需后台支持,具备快速、体验好、易集成等优势。本文介绍如何利用插件的`camera-view`功能,通过检测人体站位视角(前、后、左、右),确保运动时的最佳识别率和用户体验。代码示例展示了如何实现视角检查,确保用户正或背对摄像头,为后续运动检测打下基础。
|
23天前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十七、如何识别用户上传视频中的人体、运动、动作、姿态?
【云智AI运动识别小程序插件】提供人体、运动、姿态检测的AI能力,支持本地原生识别,无需后台服务,具有速度快、体验好、易集成等优点。本文介绍如何使用该插件实现用户上传视频的运动识别,包括视频解码抽帧和人体识别的实现方法。
|
2月前
|
人工智能 小程序 IDE
【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
随着AI技术的发展,各大厂商推出的AI运动APP如“乐动力”、“天天跳绳”等,使云上运动会、线上健身等概念大热。本文将指导你如何利用“云智AI运动识别小程序插件”,在微信小程序中实现类似功能,包括工具搭建、服务启动及数据回传等步骤,助力开发者高效开发AI运动小程序。
【一步步开发AI运动小程序】九、姿态辅助调试桌面工具的使用
|
1月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十三、自定义一个运动分析器,实现计时计数02
本文介绍如何利用“云智AI运动识别小程序插件”开发AI运动小程序,详细解析了俯卧撑动作的检测规则构建与执行流程,涵盖卧撑和撑卧两个姿态的识别规则,以及如何通过继承`sports.SportBase`类实现运动分析器,适用于小程序开发者。
|
1月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十二、自定义一个运动分析器,实现计时计数01
随着AI技术的发展,AI运动APP如雨后春笋般涌现,如“乐动力”、“天天跳绳”等,推动了云上运动会、线上健身等热潮。本文将指导你从零开始开发一个AI运动小程序,利用“云智AI运动识别小程序插件”,介绍运动识别原理、计量方式及运动分析器基类的使用,帮助你在小程序中实现运动计时和计数功能。下篇将继续探讨运动姿态检测规则的编写。
|
2月前
|
人工智能 JSON 小程序
【一步步开发AI运动小程序】八、利用body-calc进行姿态识别
随着AI技术的发展,各大厂商推出的如“乐动力”、“天天跳绳”等AI运动APP,使得云上运动会、线上健身等概念风靡一时。本文将引导读者从零开始开发一个AI运动小程序,使用“云智AI运动识别小程序插件”,介绍人体姿态检测规则、规则编写语法、执行检测规则运算及姿态检测实战等内容,助力开发者轻松实现AI运动小程序的开发。
【一步步开发AI运动小程序】八、利用body-calc进行姿态识别
|
24天前
|
人工智能 小程序 数据处理
uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。
下一篇
开通oss服务