Another option is to handle it entirely on the client side via jQuery (in a 
script tag or a loaded script):

$(function() {
  $('select[name="City"]').change(function() {
     ajax('function_name', ['City'], 'target_div');
  });
});

Anthony

On Monday, February 6, 2012 9:25:29 AM UTC-5, DenesL wrote:
>
> You can use the element function on the created form to locate the 
> field (as explained in the book section "Server-side DOM and Parsing" 
> in chapter 5) and add the onchange to it: 
>
> c = form.element(_name='City') 
> c['onchange'] = XML("ajax('function_name', ['City'], 'target_div');") 
>
>
>
> On Feb 6, 4:05 am, shartha <m.mirghorb...@gmail.com> wrote: 
> > I have a drop-down menu created from a field in my DB using 
> > SQLForm.factory. How can I assign an Ajax function to the onchange 
> > event of the drop-down menu? 
> > 
> > The drop-down menu is created from a table called "cities" by: 
> > 
> > form = SQLFORM.factory(Field('City',  requires=IS_IN_DB(db, 
> > 'cities.id', '%(name)s',error_message='Please select a city', 
> > zero=None)), submit_button='Next') 
> > 
> > I would like to have an ajax function that has the city selected from 
> > the drop-down menu as a parameter and is run every time the selection 
> > changes. Something like: 
> > 
> > onchange="ajax('function_name', ['City'], 'target_div');" 
> > 
> > Any help would be appreciated. 
> > 
> > Thanks.

Reply via email to