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

简介: 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


目录
相关文章
|
14天前
|
小程序 前端开发 API
小程序全栈开发中的多端适配与响应式布局
【4月更文挑战第12天】本文探讨了小程序全栈开发中的多端适配与响应式布局。多端适配涉及平台和设备适应,确保统一用户体验;响应式布局利用媒体查询和弹性布局维持不同设备的布局一致性。实践中,开发者可借助跨平台框架实现多平台开发,运用响应式布局技术适应不同设备。同时,注意兼容性、性能优化和用户体验,以提升小程序质量和用户体验。通过这些方法,开发者能更好地掌握小程序全栈开发。
|
14天前
|
小程序 前端开发 API
微信小程序全栈开发中的异常处理与日志记录
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的异常处理和日志记录,强调其对确保应用稳定性和用户体验的重要性。异常处理涵盖前端(网络、页面跳转、用户输入、逻辑异常)和后端(数据库、API、业务逻辑)方面;日志记录则关注关键操作和异常情况的追踪。实践中,前端可利用try-catch处理异常,后端借助日志框架记录异常,同时采用集中式日志管理工具提升分析效率。开发者应注意安全性、性能和团队协作,以优化异常处理与日志记录流程。
|
14天前
|
小程序 安全 数据安全/隐私保护
微信小程序全栈开发中的身份认证与授权机制
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的身份认证与授权机制。身份认证包括手机号验证、微信登录和第三方登录,而授权机制涉及角色权限控制、ACL和OAuth 2.0。实践中,开发者可利用微信登录获取用户信息,集成第三方登录,以及实施角色和ACL进行权限控制。注意点包括安全性、用户体验和合规性,以保障小程序的安全运行和良好体验。通过这些方法,开发者能有效掌握小程序全栈开发技术。
|
14天前
|
小程序 前端开发 安全
小程序全栈开发中的跨域问题及其解决方案
【4月更文挑战第12天】本文探讨了小程序全栈开发中的跨域问题及其解决方案。跨域问题源于浏览器安全策略,主要体现在前后端分离、第三方服务集成和数据共享上。为解决此问题,开发者可采用CORS、JSONP、代理服务器、数据交换格式和域名策略等方法。实践中需注意安全性、兼容性和性能。通过掌握这些解决方案,开发者能更好地处理小程序的跨域问题,提升用户体验。
|
14天前
|
JavaScript 前端开发 小程序
微信小程序全栈开发之性能优化策略
【4月更文挑战第12天】本文探讨了微信小程序全栈开发的性能优化策略,包括前端的资源和渲染优化,如图片压缩、虚拟DOM、代码分割;后端的数据库和API优化,如索引创建、缓存使用、RESTful API设计;以及服务器的负载均衡和CDN加速。通过这些方法,开发者可提升小程序性能,优化用户体验,增强商业价值。
|
14天前
|
小程序 前端开发 JavaScript
微信小程序全栈开发中的PWA技术应用
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中PWA技术的应用,PWA结合Web的开放性和原生应用的性能,提供离线访问、后台运行、桌面图标和原生体验。开发者可利用Service Worker实现离线访问,Worker处理后台运行,Web App Manifest添加桌面图标,CSS和JavaScript提升原生体验。实践中需注意兼容性、性能优化和用户体验。PWA技术能提升小程序的性能和用户体验,助力开发者打造优质小程序。
|
7天前
|
小程序 JavaScript Java
基于SpringBoot+Vue+uniapp微信小程序的微信课堂助手小程序的详细设计和实现
基于SpringBoot+Vue+uniapp微信小程序的微信课堂助手小程序的详细设计和实现
36 3
|
14天前
|
小程序 前端开发 API
小程序全栈开发中的RESTful API设计
【4月更文挑战第12天】本文探讨了小程序全栈开发中的RESTful API设计,旨在帮助开发者理解和掌握相关技术。RESTful API基于REST架构风格,利用HTTP协议进行数据交互,遵循URI、客户端-服务器架构、无状态通信、标准HTTP方法和资源表述等原则。在小程序开发中,通过资源建模、设计API接口、定义资源表述及实现接口,实现前后端高效分离,提升开发效率和代码质量。小程序前端利用微信API与后端交互,确保数据流通。掌握这些实践将优化小程序全栈开发。
|
14天前
|
SQL 安全 小程序
探索微信小程序全栈开发的安全性问题
【4月更文挑战第12天】本文探讨了微信小程序全栈开发中的安全性问题,包括数据安全、接口安全、隐私保护和代码安全。为解决这些问题,建议采取数据加密、使用HTTPS协议、身份认证与授权、输入验证、安全审计及漏洞扫描以及安全培训等措施。通过这些方法,开发者可提升小程序安全性,保护用户隐私和数据。
|
14天前
|
小程序 前端开发 JavaScript
小程序全栈开发:前端与后端的完美结合
【4月更文挑战第12天】本文介绍了小程序全栈开发,涵盖前端和后端的关键点。前端使用WXML和WXSS进行页面结构和样式设计,JavaScript处理逻辑及组件使用;后端采用Node.js等语言处理业务逻辑、数据库设计和API接口开发。前端与后端通过数据交互实现结合,采用前后端分离模式,支持跨平台运行。调试测试后,提交微信审核并上线运营。掌握前端后端结合是小程序成功的关键。