I'm setting up a fairly complex (for us) ViewModel for report generation, which will have multiple nested fields that need to call functions on each other and on parents and children. I'd like to be able to test it in the browser console by calling the VM functions directly, but I've found that "this" is different in the functions depending on whether they've been called by a data-bind click event, vs being called directly from the console command line.
Here's a Dojo setup showing the problem: https://dojo.telerik.com/ucalOzoW
Open the browser console and click Run in Dojo. You'll see it call testVm.funcTopLevel() with no problem. Then it calls testVm.fields.field1.funcNested() as you would from the console, and it works as I would expect, where this.id refers to the id property of the object at that level ("idField1"), and this.parent().parent().id refers to the id property of the parent object ("idTopLevel").
But then when you click the "call funcNested" button, "this" now refers to the top-level VM object, and this.parent() is undefined. I'm assuming there's something going on with how the functions are being bound to "this" in MVVM when called from a click event...
I'd like for the function's behavior and scope to be the same no matter if it's called from the console or from a click event, is there any way to do that? Or is there something I'm missing?
Thanks!