GYChen 发表于 2012-12-22 21:29:00

一道前端面试题----在javascript调试中,你是如何监测一个变量的变化的呢?

<div id="cnblogs_post_body">  这是今年百度公司暑期实习生招聘web前端开发工程师面试的面试官问本人的一道面试题。
  问题:javascript如何监控变量呢?
  答:__defineGetter__和 __defineSetter__这两个方法每次get和set的时候都会执行。不过并不是所有浏览器都支持。在Firefox下,我们可以通过object.watch(prop, handler)来实现。而在IE下,可以通过Object.defineProperty来实现。具体代码如下:
<div class="cnblogs_code"> 1 /* 2 * object.watch polyfill 3 * 4 * 2012-04-03 5 * 6 * By Eli Grey, http://eligrey.com 7 * Public Domain. 8 * NO WARRANTY EXPRESSED OR IMPLIED. USE AT YOUR OWN RISK. 9*/10 11 // object.watch12 if (!Object.prototype.watch) {13   Object.defineProperty(Object.prototype, "watch", {14         enumerable: false15         , configurable: true16         , writable: false17         , value: function (prop, handler) {18             var19               oldval = this20             , newval = oldval21             , getter = function () {22               return newval;23             }24             , setter = function (val) {25               oldval = newval;26               return newval = handler.call(this, prop, oldval, val);27             }28             ;29 30             if (delete this) { // can't watch constants31               Object.defineProperty(this, prop, {32                       get: getter33                   , set: setter34                     , enumerable: true35                     , configurable: true36                 });37             }38       }39     });40 }41 42 // object.unwatch43 if (!Object.prototype.unwatch) {44   Object.defineProperty(Object.prototype, "unwatch", {45         enumerable: false46         , configurable: true47         , writable: false48         , value: function (prop) {49             var val = this;50             delete this; // remove accessors51             this = val;52       }53     });54 }
页: [1]
查看完整版本: 一道前端面试题----在javascript调试中,你是如何监测一个变量的变化的呢?