初学者哆啦 2021-05-21 14:13 采纳率: 40%
浏览 91
已采纳

Vue监听js中的变量

//TestFun.js
const b = {zhihu: 0}
let a = new Proxy({}, {
    set: function (obj, prop, value) {
        obj[prop] = value;

        if (prop == 'zhihu') {
            // console.log("set " + prop + ": " + obj[prop]);
            let nnn = new MyClass()
            nnn.jjj(value)
            b.zhihu = value
            console.log('b:' + b.zhihu)
        }
        return true;
    }
});
export class MyClass {
    async inc(count) {
        for (let i = 0; i < 30; i++) {
            for (let j = 0; j < 30; j++) {
                count += i + j
            }
            a.zhihu = i
        }
        return count;
    }
    async jjj(value){
        // console.log(value)
        b.zhihu = Math.random()
        console.log(b.zhihu)
        // return value
    }
}

export{
    b
}
//main
import MyWorker from 'comlink-loader!../../TestFun'
import {b} from '../../TestFun.js'
    export default {
        data() {
            return {
                counter: 0,
                continuedCount: 0,
                value: {a:0},
                arr: []
            }
        },
        methods: {
            async countP1() {
                const inst = new MyWorker();
                const objj = await new inst.MyClass();
                await objj.jjj()
                console.log(b.zhihu)
            },
            async continuedCountP() {
                const count = this.continuedCount;
                const inst = new MyWorker();
                const obj = await new inst.MyClass();
                this.continuedCount = await obj.inc(count)
                this.value = await obj.jjj()
            }
        },
        watch: {
            counter(oldval, newval) {
                console.log(oldval + ',' + newval)
            },
            'value.a':{
                handler(val){
                    console.log("value:" + val)
                }
            },
            arr:{
                handler(val){
                    console.log(val)
                },
                // deep: true
            },
            'b.zhihu':{
                handler(val){
                    console.log(val)
                },
                deep: true
            },
        },
    }

想实现js文件中的某些变量发生变动后,会触发Vue页面中的相应事件。

如有大佬能够解答,非常感激!

  • 写回答

4条回答 默认 最新

  • CSDN专家-Time 2021-05-21 14:14
    关注

    用watch,你写了watch了啊,请问哪里有问题。。

    触发事件 子向父 用emit ;父向子 用 broadcast

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥23 (标签-bug|关键词-密码错误加密)
  • ¥66 比特币地址如何生成taproot地址
  • ¥20 数学建模数学建模需要
  • ¥15 关于#lua#的问题,请各位专家解答!
  • ¥15 什么设备可以研究OFDM的60GHz毫米波信道模型
  • ¥15 不知道是该怎么引用多个函数片段
  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决