Hi, I'm trying to implement a drop-down based on the one at http://www.web2pyslices.com/slice/show/1467/cascading-drop-down-lists-with-ajax
While the example above works great, I don't seem to be making a successful ajax call in my adaptation.. Basically, the second dropdown does not reload (it gets removed by jQuery .remove(), never to return) when the first dropdown changes. if I remove this line from the above w2pslices example: ajax('maker', ['category_name'], 'shadow_clone'); ...then it fails just like my code does, making me think my ajax call does not happen. The db.district_data simply stores a title and an integer ('num_districts'). The districts always start at 1 and go up to 'num_districts' so if 'num_districts' is 3, I want to load the dropdown with the three options 1 | 2 | 3 A user selects a title in the first dropdown and selects a district in the second. I'm trying to use the ajax call to load the second dropdown based on the contents of the first... so when a user selects a title from the first dropdown, they should then see the other dropdown updated and loaded with 1:num_districts (eg 1 | 2 | 3 ) for the given title. Here's my code: # model: db.define_table('district_data', Field('title', readable=False, writable=False), Field('num_districts', 'integer', default=0, readable=False, writable=False, requires=IS_INT_IN_RANGE(0, 1e100)), auth.signature, format = '%(title)s') # controller: @auth.requires_login() def td(): titles_list = [] num_districts_list = [] q1 = auth.accessible_query('read', db.district_data) records = db(q1).select() for row in records: titles_list.append(row.title) num_districts_list.append( tuple(range(1, row.num_districts+1)) ) return(locals()) @auth.requires_login() def maker(): with open('/home/JL/Desktop/results_dump.txt', 'w') as file: file.write('abc' + '\n') # file untouched / does not execute. q1 = auth.accessible_query('read', db.district_data) q2 = db.district_data.title == request.vars.title_select.replace('_', ' ') # not sure if this is necessary(?) record = db(q1&q2).select().first() result = "<select name='district_select'>" district_choices = tuple(range(1, record.num_districts+1)) for dc in district_choices: result += "<option value='" + str(dc) + "'>" + str(dc) + "</option>" result += "</select>" return XML(result) # view {{extend 'layout.html'}} <form enctype="multipart/form-data" action="{{URL()}}" method="post"> <select name='title_select' onchange="jQuery(district_select).remove(); ajax('maker', ['title_select'], 'shadow_clone');"> {{for title in titles_list:}} <option value="{{=title}}" {{=" selected='selected'" if str(title)==request.vars.title_select else ""}}> {{=title}} </option> {{pass}} </select> <span id='shadow_clone'></span> <select name='district_select' > {{for district in num_districts_list[0]:}} <option value="{{=str(district)}}" {{=XML(" selected='selected'") if str(district)==str(request.vars.district_select) else ""}}> {{=str(district)}} </option> {{pass}} </select> <input type="submit" value='Submit'> </form> Thanks very much for looking at this, -jl -- --- You received this message because you are subscribed to the Google Groups "web2py-users" group. To unsubscribe from this group and stop receiving emails from it, send an email to web2py+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/groups/opt_out.