Friday, March 27, 2015

Re: QueryDict and its .dict() method - why does it do that?

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1

iQIcBAEBCAAGBQJVFbtPAAoJEC0ft5FqUuEhZUEQALwnMefHp6apBz/oZA1r/6VW
NadRAKzUEGwnYJFth5967gt/N0qpTO6r+A2X/P2dtD9MqBfS/4MVz+eLdXfvkwo1
6wX4CvCLZIBAeJh5ReQfzM/XeUeZKQRhefiOz2qsKdrsk3d4pC/Ukfees2ozCIBS
F5qWgVTg8SBBewGAq5n2qB5m03Y5qgk5F1fChosFNrg4vMnk/GE70lYcZvkQ+QC6
XBcsEKM1yLIUoqHRzwpGDxuiOSgaPFuG/uV6isWpXzkLo/B88ybtYOvR/q5/iGgE
qfvkQggGbRsCl1xBs4BHqvLh0qbO8hKW9IQ3q/eRQNvwubxb9duChSOtR9dzwBt+
5l/7s0p4IFxa5fUwK43ZisIJEasTRb7a/HU+aGEWki5KfW9+bGo6ffMKTnTQk97K
16/OOhdbIcuQxtw5jk6EiaYy1M8Qe7kbs6gwEwerb1PTo3w0X63CqrcBvkNWVMkx
X0lF+781wjf+i2Y3TZ4lEpttdo8GxTM6ooXUKk1d1I8GwMBXnmIHQhiEBtPC4T4U
w984EnG43e8gq6Jn39adpPcJy0VVlCHEZlGwr02yPA58eIeB/nmyCQUJU4e4ZvV8
53/Dikh7fvhpkKPH8e/uzNsXx5g3CfoKr3OmWyMIe3o4bKzBsFr4tkC1HvM708f/
suocea3OZgbkcUSFznE7
=3EpD
-----END PGP SIGNATURE-----
Hi Gabriel,

On 03/27/2015 02:10 PM, Gabriel Pugliese wrote:
> I perfectly understand what you are saying. It was very clear and
> informative, but do not agree with the design chosen here. Below is just
> an opinion and you do not have to agree with it:

That's good :-) I probably won't continue with the design discussion
past this email, because I don't think we will reach a conclusion which
convinces the Django core team to change the design.

> My buddies have given PHP and Rails examples, but there are other
> frameworks from other languages that do that the same way.

I'm not personally aware of them, but I believe you. If this behavior
ever becomes part of an accepted RFC, I'm sure Django will implement it
in core :-)

> I mean,
> what's the advantage here doing differently from others?

I already tried to explain that: simple, predictable behavior that
exposes the underlying querystring data directly to the user, with no
munging of values which might be unexpected by some users.

Django provides the simple, predictable basic behavior. If you want this
extended special behavior, it's easy to implement it on top of what
Django provides.

> And I don't agree it follows KISS if I need to re-iterate on the result
> again to get a dict from it (one clear example usage is destructuring as
> named function parameters).

If you just want a dict, you don't need to iterate, you can just use the
.dict() method (or other options already explained earlier in this thread).

If you want a dict interpretation of the querystring *that handles keys
with brackets in their names in a special way*, then yes, you have to
implement that yourself. It wouldn't be hard to implement, and then that
code could be shared by all who want it.

Carl

--
You received this message because you are subscribed to the Google Groups "Django users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to django-users+unsubscribe@googlegroups.com.
To post to this group, send email to django-users@googlegroups.com.
Visit this group at http://groups.google.com/group/django-users.
To view this discussion on the web visit https://groups.google.com/d/msgid/django-users/5515BB4F.3010502%40oddbird.net.
For more options, visit https://groups.google.com/d/optout.

No comments:

Post a Comment