mirror of
https://github.com/moodle/moodle.git
synced 2025-08-07 18:06:51 +02:00
MDL-54778 form: Fix lots of issues with form dependencies
The original issue here was that each loop of the named values did not check for prototypal properties. As a result, if there were input fields with names such as 'sort', 'valueOf', 'constructor', etc. these would return their prototypal functions instead of a falsy value, and be treated as though they are array - hence the 'Cannot push to Function' type error. Following on from this I discovered that the data stores were being created as arrays, but used as objects. This can also cause issues with some form input names -- e.g. if they are numeric. These two issues were resolved together by correctly storing them in objects, and checking that those objects had real properties (hasOwnProperty). This itself has to use the prototypal function to cater for the potential of a field name called 'hasOwnProperty'. I also found that the instance value stores were being initialised in the prototype (and therefore shared), which meant that there were numerous issues if two forms were present on the same page, or one form replaced an existing one (e.g. forms initialised in JS). In addition, it also became apparant that several values were being used outside of scope, or in the wrong scope. This caused further issues when creating multiple forms on a page.
This commit is contained in:
parent
49619ce243
commit
badbaa64e3
1 changed files with 530 additions and 501 deletions
1031
lib/form/form.js
1031
lib/form/form.js
File diff suppressed because it is too large
Load diff
Loading…
Add table
Add a link
Reference in a new issue