微信小程序实现类Vue-watch数据监听

1. 在 app.js 里了定义一个全局函数,当然也可以单独写一个模版,再通过引入模块的方式来调用

// 监听页面数据变化
initWatch(_page) {
    if (!_page) {
        console.error('未检测到Page对象,请将当前page传入该函数');
        return false;
    }
    if (!_page.watch) { //判断是否有需要监听的字段
        console.error('未检测到Page.watch字段(如果不需要监听,请移除initWatch的调用片段)');
        return false;
    }
    let _dataKey = Object.keys(_page.data);
    Object.keys(_page.watch).map((_key) => { //遍历需要监听的字段
        _page.data['__' + _key] = _page.data[_key]; //存储监听的数据
        if (_dataKey.includes(_key)) { //如果该字段存在于Page.data中,说明合法
            Object.defineProperties(_page.data, {
                [_key]: { //被监听的字段
                    enumerable: true,
                    configurable: true,
                    set: function(value) {
                        let oldVal = this['__' + _key];
                        if (value !== oldVal) { //如果新设置的值与原值不等,则触发监听函数
                            setTimeout(function() { //为了同步,否则如果回调函数中有获取该字段值数据时将不同步,获取到的是旧值
                                _page.watch[_key].call(_page, oldVal, value); //设置监听函数的上下文对象为当前的Page对象并执行
                            }.bind(this), 0)
                        }
                        this['__' + _key] = value;
                    },
                    get: function() {
                        return this['__' + _key]
                    }
                }
            })
        } else {
            console.error('监听的属性[' + _key + ']在Page.data中未找到,请检查~')
        }
    })
}

2. 在具体页面里调用 initWatch 函数,并编写要watch的相关字段

const app = getApp()
Page({
    data: {
        currYear: ''
    },
    watch: {
    	// 需要监听的字段
        'currYear': function (value) {
            console.log('监听数据-currYear', value, this)
            // ......
        }
    },
    onLoad() {
        app.initWatch(this) // 初始化需要监听的字段
    }
})

参考链接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue.js是一个流行的JavaScript框架,用于构建用户界面。Vue 3是Vue.js的最新版本,它引入了许多新特性和改进,使得开发微信小程序变得更加简单和高效。 要在Vue 3中开发微信小程序,你可以按照以下步骤进行: 1. 安装Vue CLI:首先,你需要安装Vue CLI,它是一个用于快速搭建Vue项目的脚手架工具。你可以使用以下命令进行安装: ``` npm install -g @vue/cli ``` 2. 创建项目:使用Vue CLI创建一个新的Vue项目。你可以使用以下命令创建一个基本的Vue项目: ``` vue create my-project ``` 在创建项目时,你可以选择使用默认的配置或者手动选择所需的特性。 3. 配置微信小程序:进入到项目目录中,然后使用以下命令安装微信小程序的插件: ``` vue add @vant/weapp ``` 这个插件将会自动配置微信小程序所需的文件和依赖。 4. 开发微信小程序:现在你可以开始在Vue项目中开发微信小程序了。你可以使用Vue的组件化开发方式来构建小程序页面,并使用Vue的响应式数据绑定和指令来处理数据和事件。 5. 构建和发布:当你完成了微信小程序的开发,可以使用以下命令将项目构建为小程序可用的代码: ``` npm run build:weapp ``` 然后,你可以将构建好的代码上传到微信小程序开发者工具中进行预览和发布。 总结一下,使用Vue 3开发微信小程序可以让你享受到Vue框架的便利和强大功能。你可以使用Vue CLI快速搭建项目,并使用Vue的组件化开发方式来构建小程序页面。同时,借助Vue的响应式数据绑定和指令,你可以更加高效地处理数据和事件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Komorebi゛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值