-
Notifications
You must be signed in to change notification settings - Fork 351
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Some values are lost if an array contains both integers and strings as keys #95
Comments
This is unsupported because the original intention was to support actual arrays. After building There are many ways to solve this problem. A few I can think of are: possible option:
possible option: schema – leave the form the same but pass schema to serializer
possible option: builder object
The builder option is obviously the most powerful because any custom function could be used. This would allow the user to do things like
Anyway, I haven't made time to work on this project in a while, so if anyone wants to contribute ideas or implementations here, that'd be helpful. |
I had this problem too and I decided to add a new option. $("form").serializeObject({'numkeys':true}); |
Hello, I think the correct solution is to convert Array to Object. It's not wasted work, it's the consequence of your lazy algorithm. When the program see a bracket with numeric value, it's need to determine if it's a array i.e with consecutive and numeric key. Without the knowledge of all keys, it can't determine it. Naive approach is to loop over all keys. Lazy approach is to take the less costly choice until proven otherwise. In this case, conversion is not wasted work, it's the work you have chosen not to do immediately with lazy approach. Correct lazy algorithm need to convert properly, so no data is lost. So even with your hint, you need to correct your algorithm. In my opinion, you hint is premature optimization. JavaScript is fast enough to transform array to object in most cases. |
Don't overlook the fact that this kind of mixing behaviour is explicitly defined in the tests and has been discouraged for a long time https://github.com/macek/jquery-serialize-object/blob/master/test/unit/add-pair-test.js#L49-L55
This isn't the exact case we're talking about, but it's under the same umbrella. Mixing types is frowned upon and makes it harder for the serializer to figure out what the correct output should be. I'm have a greater appreciation for type inference than I did 3 years ago, but I still mostly prefer explicit over implicit behavior. Also consider the fact that the plugin is essentially 3 years old and didn't understand it's use case perfectly at the time of its conception. Since then there have been countless discussions about what improvements can be made to the underlying serializer, but few people have been willing to contribute the hard work to make effective changes - not the tiny incremental patches that only make the serializer more complex and increase its fragility. |
Say you have three text inputs:
When serializing this form, the first two fields are lost in the resulting object. I think the reason is in lines 62 through 70. In the first two iterations
myname
is detected as "fixed" (line 64), while in the third iteration it's detected as "named" (line 69). This leads to the first two values being overwritten by the third.The text was updated successfully, but these errors were encountered: