微信小程序实现数值监听(页面和组件属性)

简介

目前文章主要介绍对页面属性值的监听以及组件属性值的监听。需要异页面监听数据,请跳转至另一个文章介绍

为什么需要监听属性值

当需要通过一个属性变化时候,需要计算相应的方法等。pc网站经常需要监听属性,那么小程序应该怎么去实现?

实现方法

1、首先创建公共的watch.js

javascript 复制代码
export function setWatcher(page) {
    let data = page.data;
    let watch = page.watch;
    Object.keys(watch).forEach(v => {
        let key = v.split('.');
        let nowData = data;
        for (let i = 0; i < key.length - 1; i++) {
            nowData = nowData[key[i]];
        }
        let lastKey = key[key.length - 1];
        let watchFun = watch[v].handler || watch[v];
        let deep = watch[v].deep;
        observe(nowData, lastKey, watchFun, deep, page);
    })
}
   
function observe(obj, key, watchFun, deep, page) {
    var val = obj[key];
    if (deep && val != null && typeof val === 'object') {
        Object.keys(val).forEach(childKey => {
            observe(val, childKey, watchFun, deep, page);
        })
    }
    Object.defineProperty(obj, key, {
        configurable: true,
        enumerable: true,
        set: function(newVal) {
            watchFun.call(page, newVal, val); 
            val = newVal;
            if (deep) {
                observe(obj, key, watchFun, deep, page);
            }
        },
        get: function() {
            return val;
        }
    })
}
module.exports = {
    setWatcher: setWatcher
}

2、在页面引用公共的watch.js。

javascript 复制代码
import { setWatcher } from '../../utils/watch';

3、初始化监听方法

javascript 复制代码
setWatcher(this);//可以放进onload或者input里面等

4、写入监听方法

javascript 复制代码
//page页面
watch: {
        val(v) {
        console.log(v)
        },
        count: {//监听count属性值
        handler(v,o) {
            console.log('新值:'+v,'旧值:'+o)
            if(v!==o){
            console.log('被改了')
            }else{
            console.log('没改')
            }
        },
        deep: true
        }
    },
//组件就调用observe方法

小结

微信小程序监听属性值非常的简单,只需要调用公共的js然后监听属性值即可。大大提高开发的效率。有不足之处望指正修改,一起探讨哦~!

相关推荐
Hyyy6 小时前
普通前端续命周报——第1周
前端·javascript
KaMeidebaby7 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
2501_940041747 小时前
纯前端创意交互:五款全新实用工具与视觉应用生成指南
前端·交互
刀法如飞7 小时前
《道德经》简单解说版-第 2 章:天下皆知美之为美
前端·后端·面试
发现一只大呆瓜9 小时前
超全 Vite 性能优化指南:网络、资源、预渲染三维落地方案
前端·面试·vite
IT_陈寒10 小时前
Vue的computed属性怎么突然不更新了?
前端·人工智能·后端
智商不够_熬夜来凑10 小时前
【Picker】单选多选
前端·javascript·vue.js
米饭不加菜10 小时前
Typora 原生流程图语法完全指南(Flowchart.js)
前端·javascript·流程图
scan72410 小时前
langgraphy条件边
前端·javascript·html
冰小忆11 小时前
类变量在继承场景下的初始化规则是怎样的?
java·前端·数据库