Solved

Submit an ASP.NET form in JQuery Facebox

Posted on 2008-10-21
4
3,007 Views
Last Modified: 2012-05-05
I am pulling my hair out trying to find a way of normally submitting an ASP.NET form that is a JQuery FaceBox window and retreiving the information! Sounds like it should be simple but it isn't. I can put the form in the FaceBox window but once the form has been submitted I can't retreive the data.

Does anyone know a way to do this?

If nobody knows any way then is there any lightbox windows that support ASP.NET forms.
0
Comment
Question by:JimDestruct
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
4 Comments
 
LVL 16

Expert Comment

by:sh0e
ID: 22770764
Can you post a demo?
Is the form being inserted into the DOM?

There is also one other thing, if you are using ASP.NET master pages, the id is generated by prepending names onto the id.  You will need to make use of Control.ClientID in your .aspx.cs code.
0
 
LVL 1

Author Comment

by:JimDestruct
ID: 22774351
Hiya, I have posted my current script below. Its not using a masterpage at the moment, it is just a single page I was using to try and get it to work properly. The form seems to submit with a LinkButton but I am unable to retreive the form values. If I however change the LinkButton to a Button then it doesnt submit at all!
    <form id="form1" runat="server">
    <div>
    
    <asp:HyperLink ID="HyperLink1" NavigateUrl="#showform" 
    runat="server" rel="facebox">Click Here</asp:HyperLink>
    
    <asp:Panel ID="Form" runat="server">
    
    
    <div id="showform" style="display:none;">
      
    <p><label>Name</label>
    <asp:TextBox ID="Name" runat="server"></asp:TextBox></p>
    
    <p><label>Company</label>
    <asp:TextBox ID="Company" runat="server"></asp:TextBox></p>
    
    <p><label>Phone</label>
    <asp:TextBox ID="Telephone" runat="server"></asp:TextBox></p>
    
    <p><label>Email</label>
    <asp:TextBox ID="Email" runat="server"></asp:TextBox></p>
    
    <p><asp:LinkButton ID="LinkButton1" runat="server" OnClick="LinkButton1_Click">Submit</asp:LinkButton>
    </p>
   
    </div>
    </asp:Panel>
    
    <asp:Panel ID="Thanks" runat="server" Visible="false"> 
    <asp:Literal ID="ThankYou" runat="server" />
    </asp:Panel>
    
    </div>
    </form>
 
 
 
 
 
public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {
 
    }
 
    protected void LinkButton1_Click(object sender, EventArgs e)
    {
        char d = '"';
        string BuildList = "<script type=" + d + "text/javascript" + d + " language=" + d + "javascript" + d + ">";
        BuildList = BuildList + "jQuery.facebox('hello " + Name.Text + "')";
        BuildList = BuildList + "</script>";
        Thanks.Visible = true;
        ThankYou.Text = BuildList;
    }
}

Open in new window

0
 
LVL 16

Accepted Solution

by:
sh0e earned 500 total points
ID: 22782834
The form has to be inserted into the facebox.  Right now all it is inserting is the inputs.

    <div>
    
    <asp:HyperLink ID="HyperLink1" NavigateUrl="#showform" 
    runat="server" rel="facebox">Click Here</asp:HyperLink>
    
    <asp:Panel ID="Form" runat="server">
    
    
    <div id="showform" style="display:none;">
          <form id="form1" runat="server">
    <p><label>Name</label>
    <asp:TextBox ID="Name" runat="server"></asp:TextBox></p>
    
    <p><label>Company</label>
    <asp:TextBox ID="Company" runat="server"></asp:TextBox></p>
    
    <p><label>Phone</label>
    <asp:TextBox ID="Telephone" runat="server"></asp:TextBox></p>
    
    <p><label>Email</label>
    <asp:TextBox ID="Email" runat="server"></asp:TextBox></p>
    
    <p><asp:LinkButton ID="LinkButton1" runat="server" OnClick="LinkButton1_Click">Submit</asp:LinkButton>
    </p>
   
    </div>
    </asp:Panel>
    
    <asp:Panel ID="Thanks" runat="server" Visible="false"> 
    <asp:Literal ID="ThankYou" runat="server" />
    </asp:Panel>
    
    </form>
    </div>
 
 
 
 
 
public partial class _Default : System.Web.UI.Page 
{
    protected void Page_Load(object sender, EventArgs e)
    {
 
    }
 
    protected void LinkButton1_Click(object sender, EventArgs e)
    {
        char d = '"';
        string BuildList = "<script type=" + d + "text/javascript" + d + " language=" + d + "javascript" + d + ">";
        BuildList = BuildList + "jQuery.facebox('hello " + Name.Text + "')";
        BuildList = BuildList + "</script>";
        Thanks.Visible = true;
        ThankYou.Text = BuildList;
    }
}

Open in new window

0
 
LVL 1

Author Closing Comment

by:JimDestruct
ID: 31508368
Nice one! I can stop tearing my hair out now :D
0

Featured Post

Webinar: Aligning, Automating, Winning

Join Dan Russo, Senior Manager of Operations Intelligence, for an in-depth discussion on how Dealertrack, leading provider of integrated digital solutions for the automotive industry, transformed their DevOps processes to increase collaboration and move with greater velocity.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

There are a couple ways to attach a JavaScript function to dynamically created elements. You can make a new script for each element as it’s created or you can use delegation. Delegation allows a single script that is added at page creation to mat…
I found this questions asking how to do this in many different forums, so I will describe here how to implement a solution using PHP and AJAX. The logical flow for the problem should be: Write an event handler for the first drop down box to get …
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

738 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question