从 onChange 事件中获取小部件的旧值?
Get the old value of a widget from onChange event?
如何在 onChange 事件发生之前获取小部件的先前值?我知道小部件上有一个 _lastValueReported
属性,但它不包含 onChange 事件之前的值。根据 this documentation,似乎在我的小部件中像这样以声明方式执行此操作应该可行,但事实并非如此:
<script type="dojo/aspect" data-dojo-advice="before" data-dojo-event="onChange" data-dojo-args="value">
console.log('old value: ' + value);
</script>
我有一个基于 this solution in this fiddle 的解决方法,但我认为一定有更好的方法。
你需要的是watch(),它会给你newValue和oldValue。
<script type="dojo/watch" data-dojo-prop="value" data-dojo-args="prop,oldValue,newValue">
document.getElementById("statusContainer").innerHTML = "Old Value: " + oldValue + ", New Value: " + newValue;
</script>
我已经更新了你的 fiddle here。希望对你有帮助。
仅供参考,如果我只使用键盘(标签以获得焦点)并更改值,您的其他解决方案将不起作用。
如何在 onChange 事件发生之前获取小部件的先前值?我知道小部件上有一个 _lastValueReported
属性,但它不包含 onChange 事件之前的值。根据 this documentation,似乎在我的小部件中像这样以声明方式执行此操作应该可行,但事实并非如此:
<script type="dojo/aspect" data-dojo-advice="before" data-dojo-event="onChange" data-dojo-args="value">
console.log('old value: ' + value);
</script>
我有一个基于 this solution in this fiddle 的解决方法,但我认为一定有更好的方法。
你需要的是watch(),它会给你newValue和oldValue。
<script type="dojo/watch" data-dojo-prop="value" data-dojo-args="prop,oldValue,newValue">
document.getElementById("statusContainer").innerHTML = "Old Value: " + oldValue + ", New Value: " + newValue;
</script>
我已经更新了你的 fiddle here。希望对你有帮助。
仅供参考,如果我只使用键盘(标签以获得焦点)并更改值,您的其他解决方案将不起作用。