1

我正在尝试将 lodash_.debounce函数用于视图模型方法,但即使我尝试在该方法中执行但没有成功canjs DefineMap,这似乎也很棘手:thisinit

export const ViewModel = DefineMap.extend({
 init() {
  this.myMethod = _.debounce(this.myMethod, 200)
 },
 myMethod() {
  // cool stuff here
 }
})

任何帮助表示赞赏!

4

1 回答 1

3

因为默认情况下 DefineMap 是密封的,并且您可能希望对 的各个实例进行独立限制ViewModel,所以您希望这样做:

var time = new Date();

var ViewModel = can.DefineMap.extend({
 id: "number",
 myMethod: {
   type: "any",
   default(){

     var fn = _.debounce(function(){
       console.log(this.id+" says Hi at "+(new Date() - time))
     },100);
     return fn;
   }
 }
});

这基本上将myMethod属性设置为去抖动功能。您可以在这里看到它的实际效果:http: //jsbin.com/nekelak/edit ?html,js,console

于 2018-04-15T21:27:03.413 回答