【微信小程序】数据绑定

简介: 不同于AngularJS的双向数据绑定,小程序仅实现了从逻辑层传递到渲染层的数据绑定,反之则不可以。

d1dba04e3e584c66801906b37de041db.gif


🏆今日学习目标:第十一期——数据绑定

😃创作者:颜颜yan_

✨个人主页:颜颜yan_的个人主页

⏰预计时间:25分钟

🎉专栏系列:我的第一个微信小程序


前言


哈喽大家好,本期是微信小程序专栏第十一期,本期主要是通过将post.wxml页面的数据移植到post.js中来学习数据绑定。


注意:每期内容是连载呢,建议大家可以看看往期内容,更好理解噢~

实现数据绑定


如何让data中的数据在页面中显示呢,小程序采用数据绑定的机制来做数据的初始化和更新。


小程序的脚本逻辑是运行在JSCore中,JSCore是一个没有DOM的环境,它完全抛弃了DOM结构,我们只能使用数据绑定来做数据的相关操作


不同于AngularJS的双向数据绑定,小程序仅实现了从逻辑层传递到渲染层的数据绑定,反之则不可以。


小程序使用Page方法参数里的data变量作为数据绑定的桥梁,直接写在data里的数据,被称为数据绑定的初始化数据。


小程序的数据绑定方式有以下两种,接下来我们来看看吧~


初始化数据绑定


初始化数据绑定通常将这些数据直接写在Page方法参数的data对象下面。


post.js


如下,我们先在post.js中添加一个临时变量作为测试数据,包括以下内容。


    /**
     * 页面的初始数据
     */
    data: {
        date:"Nov 9 2022",
        title:"那个不为人知的故事",
        postImg:"/images/post/unknow-story.jpg",
        avatar:"/images/avatar/avatar-5.png",
        content:"超人气作者Twentine(无量渡口)经典之作,直击心底深处的柔软。这是杨昭和陈铭生的故事,这是卧底缉毒警察的故事。 你始终不曾离去,你永远在我心底。",
        readingNum:10989,
        collectionNum:1867,
        commentNum:999
    },


post.wxml


接下来,对post.wxml文件做一些改动,就可以让wxml能够“接收”这些初始化数据。


小程序使用Mustache语法双大括号{{}}在wxml组件里进行数据绑定。


    <!-- 文章列表 -->
    <view class="post-container">
        <view class="post-author-date">
            <image src="{{avatar}}"></image>
            <text>{{date}}</text>
        </view>
        <text class="post-title">{{title}}</text>
            <image class="post-image" src="{{postImg}}" mode="aspectFit"></image>
            <text class="post-content">{{content}}</text>
            <!-- 收藏 浏览 评价-->
            <view class="post-like">
                <image src="/images/icon/wx_app_collect.png"></image>
                <text>{{readingNum}}</text>
                <image src="/images/icon/wx_app_view.png"></image>
                <text>{{collectionNum}}</text>
                <image src="/images/icon/wx_app_message.png"></image>
                <text>{{commentNum}}</text>
            </view>
    </view>


从以上代码我们可以看到双大括号{{}}中,写入了一些变量名。变量名称同js文件里data对象的属性名称是相同的。所以,数据绑定只需要将data对象的属性名填入到双大括号{{}}中即可。MINA框架会自动在运行时用data数据替换这些{{}}。


如下,文章的数据正常显示出来了,这说明数据绑定成功了。


478c8a6edcd34c94911eb3328810ac24.png


初始化数据的绑定过程


接下来,我们通过页面生命周期图解来了解初始化数据的绑定过程~


6657f2dfd41e4d0495b944bac779fe79.jpg


当页面执行了一个onShow函数后,逻辑层会收到一个通知(Notify);随后逻辑层会将data对象以json的形式发送到View视图层(Send Initial Data),视图层接收初始化数据后,开始渲染并显示初始化数据(First Render),最终将数据呈现在开发者的眼前。


注意:如果数据绑定是作用在组件的属性中,则一定要在{{}}外边加上双引号,否则小程序会报错。如果是内容型的数据绑定,则不需要加双引号。


查看数据绑定对象


调试——AppData可以查看数据情况。


AppData面板对于调试和理解数据绑定有非常重要的作用,所以,当我们遇到数据绑定相关的问题时,就可以打开AppData面板来查看具体的数据绑定情况。


AppData下的数据以页面为组织单位,现在只在post页面做了数据绑定,所以AppData里面只有这一个页面的数据。如果同时绑定多个页面,则会显示多个页面的数据。


ded0128d8b7f4debbec565f47ba16181.png


将页面的数据以json的形式呈现


如下,点击Tree,切换为Code,就可以将页面的数据以json的形式呈现了。


67a94b2487be4334a00d4555197ccf7e.png

68e85e83edf44504854cd15d0a2c9c33.png


注意:json格式的数据,非常利于我们快速复制这些数据。


绑定复杂对象


在上面的代码中,data对象是最简单的js对象,它的属性值都是文本与数字,接下来,我们增加对象和数组看看,如下👇


 /**
     * 页面的初始数据
     */
    data: {
        object:{
            date:"Nov 9 2022",
        },
        title:"那个不为人知的故事",
        postImg:"/images/post/unknow-story.jpg",
        avatar:"/images/avatar/avatar-5.png",
        content:"超人气作者Twentine(无量渡口)经典之作,直击心底深处的柔软。这是杨昭和陈铭生的故事,这是卧底缉毒警察的故事。 你始终不曾离去,你永远在我心底。",
        readingNum:10989,
        collectionNum:{
            array:[1867]
        },
        commentNum:999
    },


此时,相应的wxml页面里也需要作出调整,如下👇


f6c3ef27a1df478d965ef53eebc238f1.png


setData方法实现数据绑定


这种方式也可以理解为数据更新,这样的数据更新将引起页面的Rerender(重新渲染。)


setData方法位于Page对象的原型链上:Page.prototype.setData。大多数情况下,我们使用this.setData的方式来调用这个方法。setDate的参数接受一个对象以Key和Value的形式将this.data中的Key对应的值设置成value。


注意:


1.setData会改变this.data变量里相同的Key的值。

2.setData执行后会通知逻辑层执行Rerender,并立刻重新渲染视图。


如下,在data下面添加一个onLoad函数,并使用setData方法👇


0aef6e8ba096478a9ce8f66cfcbd185d.png


运行后发现,文章标题由设定的“那个不为人知的故事”更改成了“那个故事”,其他的数据没有改变,是因为我们使用this.setData只更新了title这一个数据,没有更新其他的数据。


22ccdfaa36474daa9181cf85449a364a.png


注意:setData参数中的key是非常灵活的,以下是key可能出现的形式。


key使用字符串表示


885098dd3ab143eaa6637e02ce7c0edf.png


key使用数组表示


be5a2dffdafe4a8f8583385dad4e4b08.png

d6524a6ff59c4f96a314e5bd1c425875.png


key使用object对象表示


638794e5d20545e8a2e7c5efdd308300.png

17c6c9e113644df1984502044c997d8a.png


用this.Data所绑定或者更新的数据并不要求在this.data中预先定义


如下,我们来看看这种方法的代码吧~


post.js


 /**
     * 页面的初始数据
     */
    data: { 
    },
    /**
     * 生命周期函数--监听页面加载
     * option为页面跳转所带来的参数
     */
    onLoad:function(options) {
        var StoryData = {
            object:{
                date:"Nov 9 2022",
            },
            title:"那个不为人知的故事",
            postImg:"/images/post/unknow-story.jpg",
            avatar:"/images/avatar/avatar-5.png",
            content:"超人气作者Twentine(无量渡口)经典之作,直击心底深处的柔软。这是杨昭和陈铭生的故事,这是卧底缉毒警察的故事。 你始终不曾离去,你永远在我心底。",
            readingNum:10989,
            collectionNum:{
                array:[1867]
            },
            commentNum:999
        }
        this.setData({
            postData: StoryData
        })
    },


相应的wxml也要做出调整噢~


post.wxml


 <!-- 文章列表 -->
    <view class="post-container">
        <view class="post-author-date">
            <image src="{{postData.avatar}}"></image>
            <text>{{postData.object.date}}</text>
        </view>
        <text class="post-title">{{postData.title}}</text>
            <image class="post-image" src="{{postData.postImg}}" mode="aspectFit"></image>
            <text class="post-content">{{postData.content}}</text>
            <!-- 收藏 浏览 评价-->
            <view class="post-like">
                <image src="/images/icon/wx_app_collect.png"></image>
                <text>{{postData.readingNum}}</text>
                <image src="/images/icon/wx_app_view.png"></image>
                <text>{{postData.collectionNum.array[0]}}</text>
                <image src="/images/icon/wx_app_message.png"></image>
                <text>{{postData.commentNum}}</text>
            </view>
    </view>


总结


以上就是今天的学习内容啦~

如果有兴趣的话可以订阅专栏,持续更新呢~

咱们下期再见~


f37046e1481a4aaaa0951ff292cc849f.gif

相关文章
|
8月前
|
小程序 JavaScript
【微信小程序】-- WXML 模板语法 - 数据绑定(九)
【微信小程序】-- WXML 模板语法 - 数据绑定(九)
|
3月前
|
XML 小程序 JavaScript
小程序入门之项目配置说明和数据绑定
小程序入门之项目配置说明和数据绑定
52 1
|
4月前
|
小程序 JavaScript
微信小程序学习之数据绑定,事件绑定,事件传参与数据同步的学习记录
本文介绍了微信小程序中的数据绑定、事件绑定、事件传参与数据同步的基本概念和使用方法,包括如何在data对象中定义数据、使用mustache语法在wxml中渲染数据、绑定和处理事件、事件对象属性、事件传参以及实现输入框与data数据的同步。
微信小程序学习之数据绑定,事件绑定,事件传参与数据同步的学习记录
|
5月前
|
小程序 JavaScript 前端开发
微信小程序开发时数据是否是双向数据绑定的
微信小程序开发时数据是否是双向数据绑定的
|
5月前
|
缓存 开发框架 JavaScript
人人都能看懂的鸿蒙 “JS 小程序” 数据绑定原理 | 解读鸿蒙源码
人人都能看懂的鸿蒙 “JS 小程序” 数据绑定原理 | 解读鸿蒙源码
|
6月前
|
JavaScript
支付系统---微信支付23-数据绑定和事件,使用Vue调试要添加扩展,F12与console平级就出现了Vue,在支付资料,微信支付,04资料,工具里
支付系统---微信支付23-数据绑定和事件,使用Vue调试要添加扩展,F12与console平级就出现了Vue,在支付资料,微信支付,04资料,工具里
|
8月前
|
小程序 JavaScript
【微信小程序】数据绑定
【微信小程序】数据绑定
114 1
|
8月前
|
JavaScript 小程序
微信小程序的双向数据绑定和vue的哪里不一样?下拉刷新的方式代码示例
微信小程序的双向数据绑定和vue的哪里不一样?下拉刷新的方式代码示例
|
8月前
|
小程序 JavaScript
微信小程序——数据绑定
微信小程序——数据绑定
123 0
|
3月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
868 7