data:image/s3,"s3://crabby-images/62f22/62f229b7819ac5a535047c12cccd46be841e96a9" alt="企业数字化转型:钉钉小程序开发权威指南"
4.4.1 注册小程序页面
1.Page
Page方法接收一个Object作为参数,该参数用来指定页面的初始数据、生命周期方法、事件处理函数等。
示例代码:
data:image/s3,"s3://crabby-images/26bfd/26bfd31ecc82d4f5487d35154485ad4f390afe78" alt=""
data:image/s3,"s3://crabby-images/43c12/43c124a0e81f0fbdbba6c876ba273f6ebde42ff7" alt=""
在上述代码中,Page方法的参数列表如表4-7所示。
表4-7 Page方法的参数列表
data:image/s3,"s3://crabby-images/26279/262794c812affe7bcd291c57c3f17dcc03cc829d" alt=""
续表
data:image/s3,"s3://crabby-images/2c087/2c087ca60bf739fe2528db431decf68efc9c4436" alt=""
(1)页面初始数据data。
data是页面第一次渲染时使用的初始数据。
注意
当data作为对象时,如果在页面中修改data,则会影响该页面的不同实例。
.axml示例代码:
data:image/s3,"s3://crabby-images/ffcca/ffcca08b3edaa76a2f449670ec49726438ae1f4e" alt=""
.js示例代码:
data:image/s3,"s3://crabby-images/aba39/aba39be338f4bacc7d5adb2e5d5f5a3d9e3eb0bf" alt=""
(2)生命周期方法及其说明如表4-8所示。
表4-8 生命周期方法及其说明
data:image/s3,"s3://crabby-images/efbbb/efbbbbebfb8c6af6a092fa9b60ad4e4c477671c3" alt=""
(3)事件处理函数及其说明如表4-9所示。
表4-9 事件处理函数及其说明
data:image/s3,"s3://crabby-images/8c5ee/8c5ee3d41e6a863773c10b8cb8bf01aa631e036a" alt=""
2.Page.prototype.setData
setData方法用于将数据从逻辑层发送到视图层,同时改变对应的this.data的值。
setData方法接收一个对象作为参数。对象的键名key可以非常灵活,以数据路径的形式给出,如array[2].message、a.b.c.d,并且不需要在this.data中预先定义。
注意
● 直接修改this.data无效,无法改变页面的状态,还会造成数据不一致。
● 尽量避免一次性设置过多的数据。
示例代码:
data:image/s3,"s3://crabby-images/fcfd5/fcfd5c26ead744a70b7786aae88249f5c082f2e9" alt=""
data:image/s3,"s3://crabby-images/b4aa4/b4aa4e775bf747fb65acc6ed5e4f96e72e4d31a2" alt=""
3.Page.prototype.$spliceData
$spliceData同样用于将数据从逻辑层发送到视图层,但是相比setData,在处理长列表时,其具有更高的性能。$spliceData接收一个对象作为参数。
● 对象的键名key可以非常灵活,以数据路径的形式给出,如array[2].message、a.b.c.d,并且不需要在this.data中预先定义。
● 对象的value为一个数组(格式为[start,deleteCount,...items]),数组的第一个元素为操作的起始位置,第二个元素为删除的元素的个数,剩余的元素均为插入的数据,对应ES5中数组的splice方法。
.axml示例代码:
data:image/s3,"s3://crabby-images/c79a8/c79a829de974f5c36c782c9d83531abee6aca0fb" alt=""
.js示例代码:
data:image/s3,"s3://crabby-images/413c3/413c3289df2949df6f0c7069a69823b918c6a546" alt=""
页面输出:
data:image/s3,"s3://crabby-images/4be93/4be93413a8592c6a5c56f65a7cb212dae29db500" alt=""