Wrox Programmer Forums

Need to download code?

View our list of code downloads.

Go Back   Wrox Programmer Forums > ASP.NET and ASP > ASP.NET 4 > BOOK: Professional ASP.NET MVC 2
Password Reminder
Register
| FAQ | Members List | Calendar | Search | Today's Posts | Mark Forums Read
BOOK: Professional ASP.NET MVC 2
This is the forum to discuss the Wrox book Professional ASP.NET MVC 2 by Jon Galloway, Scott Hanselman, Phil Haack, Scott Guthrie, Rob Conery; ISBN: Professional ASP.NET MVC 2
Welcome to the p2p.wrox.com Forums.

You are currently viewing the BOOK: Professional ASP.NET MVC 2 section of the Wrox Programmer to Programmer discussions. This is a community of tens of thousands of software programmers and website developers including Wrox book authors and readers. As a guest, you can read any forum posting. By joining today you can post your own programming questions, respond to other developers’ questions, and eliminate the ads that are displayed to guests. Registration is fast, simple and absolutely free .
DRM-free e-books 300x50
 
 
Thread Tools Search this Thread Display Modes
  #1 (permalink)  
Old November 23rd, 2010, 05:12 AM
Registered User
 
Join Date: Nov 2010
Posts: 2
Thanks: 0
Thanked 0 Times in 0 Posts
Default Apply change function on one dropdown to fill another dropdown box

I am coding a small project using MVC 2 after read chapter 1 of "Professional ASP.NET MVC 2". On one of my views, there are two Select boxes, box1 is for selecting Fields, box2 for values. When the selected item of box1 changes, the values set in box2 will be changed accordingly.

Have some basic understanding from the book, I read "http://stackoverflow.com/questions/2500949/is-it-possible-to-bind-data-asynchronously-between-two-dropdownlists-in-a-view", then create the funciton as below:

In the controller, the method is:
Code:
 public ActionResult getValByFld(string thefld)
        {
            List<string> thevals = new List<string>();
            string sql = "  ";
            if (thefld == "prio")
            {
                sql = "select acode from pas. patcodes where acode <> ' ' and tcode ='TP' and ptcoactv ='A' order by acode";
            }
            else if (thefld == "purch")
            {
                sql = "select acode from pas. patcodes where acode <> ' ' and tcode ='HP' and ptcoactv ='A' order by acode";
            }
            else if (thefld == "serv")
            {
                sql = "select distinct wprhat from pas.watproaf where wprhat <> ' ' order by wprhat ";
            }

            database = DatabaseFactory.CreateDatabase("HEALTH-SOURCE");
            reader = database.ExecuteReader(CommandType.Text, sql);
            while (reader.Read())
            {
                thevals.Add(reader.GetString(0));
            }
            return Json(thevals);
        }
the view template is:
Code:
<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<ESPItry.Models.ESPIAddLev1ViewModel>" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
	AddLev1Exclu

    <script src="/Scripts/MicrosoftAjax.js" type="text/javascript"></script>
    <script src="/Scripts/MicrosoftMvcAjax.js" type="text/javascript"></script>
    <script src="/Scripts/jQuery-1.4.1.js" type="text/javascript"></script>

    <script type="text/javascript">
    $(function() { 
    $('select#fldExclu').change(function() { 
        var fldId = $(this).val();
        $.post('/ESPITrys/getValByFld', { thefld: fldId }, function(thevals) { 
            var valSelect = $('select#valExclu');
            // loop through thevals and fill the dropdown 
            $(thevals).each(function(item) { 
                valSelect.append( 
                    '<option value="' + item + '">'
                    +   '</option>'); 
            }); 
        }); 
    }); 
}); 
</script>

</asp:Content>


<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

    <h2>Add New Level 1 Exclusion</h2>

    <% using (Html.BeginForm()) {%>
        <%: Html.ValidationSummary(true) %>

        <fieldset>
            <legend>Fields</legend>
            
            <div class="editor-label">
                <%: Html.LabelFor(model => model.objLev1Exclu.fldExclu)%>
            </div>
            <div class="editor-field">
                 <%: Html.DropDownListFor(m => m.objLev1Exclu.fldExclu, Model.flds) %>
            </div>
           
            
            <div class="editor-label">
                <%: Html.LabelFor(model => model.objLev1Exclu.valExclu)%>
            </div>
             <div class="editor-field">
                 <%: Html.DropDownListFor(m => m.objLev1Exclu.valExclu, Model.vals) %>
            </div>
          
            <p>
                <input type="submit" value="Create" />
            </p>
        </fieldset>

    <% } %>

    <div>
        <%: Html.ActionLink("Back to List", "Index") %>
    </div>

</asp:Content>
When run, the view can be opened with box2 being empty. But when change box1's value, box2 can't be filled and no error is showed. Please let me know what goes wrong in my code.

Thank you very much
Susan
 


Thread Tools Search this Thread
Search this Thread:

Advanced Search
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is Off
HTML code is Off
Trackbacks are Off
Pingbacks are On
Refbacks are Off


Similar Threads
Thread Thread Starter Forum Replies Last Post
DropDown Dynamic Value Change Master/Detail moizshabbir PHP How-To 1 May 9th, 2008 06:24 AM
How to integrate search function n dropdown box jun9nah ASP.NET 1.0 and 1.1 Basics 1 July 25th, 2006 06:51 AM
How to integrate search function n a dropdown box jun9nah VB.NET 0 July 24th, 2006 10:12 PM
Fill Dropdown using AJAX sethumail2000 BOOK: Professional Ajax ISBN: 978-0-471-77778-6 1 March 6th, 2006 01:19 PM
Fill Dropdown using AJAX sethumail2000 ASP.NET 2.0 Professional 0 March 6th, 2006 09:00 AM



All times are GMT -4. The time now is 06:59 AM.


Powered by vBulletin®
Copyright ©2000 - 2019, Jelsoft Enterprises Ltd.
© 2013 John Wiley & Sons, Inc.