日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > php >内容正文

php

js给php注册网页添加实时监听,js 实现watch监听数据变化的代码

發(fā)布時間:2025/3/15 php 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js给php注册网页添加实时监听,js 实现watch监听数据变化的代码 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1.js

/**

* @desc 屬性改變監(jiān)聽,屬性被set時出發(fā)watch的方法,類似vue的watch

* @author Jason

* @study https://www.jianshu.com/p/00502d10ea95

* @data 2018-04-27

* @constructor

* @param {object} opts - 構(gòu)造參數(shù). @default {data:{},watch:{}};

* @argument {object} data - 要綁定的屬性

* @argument {object} watch - 要監(jiān)聽的屬性的回調(diào)

* watch @callback (newVal,oldVal) - 新值與舊值

*/

class watcher{

constructor(opts){

this.$data = this.getBaseType(opts.data) === 'Object' ? opts.data : {};

this.$watch = this.getBaseType(opts.watch) === 'Object' ? opts.watch : {};

for(let key in opts.data){

this.setData(key)

}

}

getBaseType(target) {

const typeStr = Object.prototype.toString.apply(target);

return typeStr.slice(8, -1);

}

setData(_key){

Object.defineProperty(this,_key,{

get: function () {

return this.$data[_key];

},

set : function (val) {

const oldVal = this.$data[_key];

if(oldVal === val)return val;

this.$data[_key] = val;

this.$watch[_key] && typeof this.$watch[_key] === 'function' && (

this.$watch[_key].call(this,val,oldVal)

);

return val;

},

});

}

}

// export default watcher;

2.html

wathc

let wm = new watcher({

data:{

a: 0,

b: 'hello'

},

watch:{

a(newVal,oldVal){

console.log(newVal, oldVal); // 111 0

}

}

})

wm.a = 111

3. 給vm.a 從新賦值 就能看到 newVal 和oldVal的變化

總結(jié)

以上所述是小編給大家介紹的js 實(shí)現(xiàn)watch監(jiān)聽數(shù)據(jù)變化的代碼,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復(fù)大家的!

總結(jié)

以上是生活随笔為你收集整理的js给php注册网页添加实时监听,js 实现watch监听数据变化的代码的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。