#
2008 nov 26 (wed) 12:31
::
Good-bye Dojo, jQuery is my new Javascript framework
Here's how it happened. I wanted to add some date pickers and a tabbed-layer area to one form, and plug in Eric Florenzano's Django threadedcomments to my templates. Eflo used jQuery in his threadedcomments example, and at first I thought I'd be able to whip up a Dojo version of that. I'm sure I could given enough time, but the clock was ticking. I took another look at jQuery and Eflo's examples, and jQuery started to feel less like a black box and more like something I could work with. I switched everything over and feel like I made a good choice.
I wish there was better writing in the Javascript space about the differences between jQuery and Dojo and the other toolkits. As a Javascript outsider it was hard to figure out the strengths and weakness of the frameworks, and the differences in the problems they're trying to solve. I also realized that some programmers seem to be using several of the frameworks together, so they seem to address different levels of the application stack. I haven't found any good writing that articulates this, and I'm not quite sure I understand it well enough to do it myself.
#
2008 nov 20 (thu) 11:55
::
Getting Dojo's dijit.Editor to work in a form
The Problem:
dijit.Editor can be inserted into a <textarea> like you insert other dijit widgets, using dojoType="dijit.Editor". The editor displays fine and works perfectly, except that it doesn't actually save to your form for some reason.
The Solution:
You have to make your actual textarea a hidden field, use <div> tags for Editor instead of <textarea>, and include some code in the dojo.addOnLoad() function that copies the text of the dijit.Editor field into the hidden field when the form is submitted. There's a good writeup of this over at Dojo Campus.org.
Thoughts
This problem is not mentioned anywhere that I could find in the official Dojo docs. I can see Dojo partisans making the case that dijit.Editor is a Dijit Application rather than one of the Dijit forms widgets, and that this justifies the special handling required. However, I think replacing the plain ol` <textarea> is probably the most common use case for dijit.Editor, so there really should be better documentation of this.
This experience makes me wonder if Dojo is really the right tool for the job I'm doing. I think I might have another look at jQuery...
P.S. JavaScript: The Good Parts is another really helpful book if you're getting into the language.







