Solved

Receiving error when using an ssi include in asp.net vb

Posted on 2009-07-12
4
257 Views
Last Modified: 2013-11-26
I have a web page programmed in asp.net vb.  I am using a server side include for a top menu.  The page I'm including is aa_includes/menu_top1.txt.  In Visual Studio 2008, when I flip to "Design" mode to see the page, I get an error "Error Creating Control - Table1, Object reference not set to an instance of an object."  I have pin pointed the problem to the actual include statement.  If I take the include out, the error goes away and I can use the "Design" mode in Visual Studio 2008.  I can't seem to figure out how to resolve this problem.  I have attached the code for the web page and attached the include file.  Thanks for any guidance.
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="Default.aspx.vb" Inherits="_Default" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <style type="text/css"></style>
    <link href="main_site.css" rel="stylesheet" type="text/css" />    
 
</head>
<body>
    <asp:Table ID="Table1"  Width="100%" Height="100%" BackColor="White" runat="server">
        <asp:TableRow>
            <asp:TableCell  HorizontalAlign="Center" VerticalAlign="Top">
                <asp:Table ID="Table2" runat="server">
                    <asp:TableRow CssClass="TopRow1">
                        <asp:TableCell>
                            <asp:Table ID="Table3" width="800" HorizontalAlign="Center" runat="server">
                                <asp:TableRow HorizontalAlign="Right">
                                    <asp:TableCell>
                                    <!-- #Include file="aa_includes/menu_top1.txt" -->
                                    </asp:TableCell>                                
                                </asp:TableRow>                                                                                    
                            </asp:Table>                                                                                                                        
                        </asp:TableCell>                    
                    </asp:TableRow>                                                                                                    
                </asp:Table>                        
            </asp:TableCell>                
        </asp:TableRow>            
    </asp:Table>
</body>
</html>

Open in new window

menu-top1.txt
0
Comment
Question by:OB1Canobie
  • 2
  • 2
4 Comments
 
LVL 15

Accepted Solution

by:
jinal earned 500 total points
ID: 24835022
Hello ,

Try to use UserControl .



/* WebUserControl3.ascx */
<%@ Control Language="VB" AutoEventWireup="true" CodeFile="WebUserControl3.ascx.vb" Inherits="WebUserControl3" %>
<asp:table ID="TopRowMenu" HorizontalAlign="Right" runat="server">
    <asp:TableRow HorizontalAlign="Right">
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='aa_aboutus/servicetimes.aspx'">Service Times</a></asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu">&nbsp;|&nbsp;</asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='aa_aboutus/directions.aspx'">Direction</a></asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu">&nbsp;|&nbsp;</asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='aa_secure/announcements.aspx'">Announcements</a></asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu">&nbsp;|&nbsp;</asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='aa_aboutus/contactus.aspx'">Contact Us</a></asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu">&nbsp;|&nbsp;</asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='quicklinks.aspx'">Quick Links</a></asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu">&nbsp;|&nbsp;</asp:TableCell>
        <asp:TableCell CssClass="TopRowMenu"><a onmouseover="CssClass='TopRowMenu'" onmouseout="CssClass='TopRowMenu'" onclick="location.href='aa_webcasts/podcasts.aspx'">Podcasts</a></asp:TableCell>
    </asp:TableRow>                            
</asp:table>
 
/* ASPX */
 
<%@ Page Language="VB" AutoEventWireup="false" CodeFile="Default.aspx.vb" Inherits="_Default" %>
<%@ Register src="WebUserControl3.ascx" tagname="WebUserControl3" tagprefix="uc1" %> 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <style type="text/css"></style>
    <link href="main_site.css" rel="stylesheet" type="text/css" />    
 
</head>
<body>
    <asp:Table ID="Table1"  Width="100%" Height="100%" BackColor="White" runat="server">
        <asp:TableRow>
            <asp:TableCell  HorizontalAlign="Center" VerticalAlign="Top">
                <asp:Table ID="Table2" runat="server">
                    <asp:TableRow CssClass="TopRow1">
                        <asp:TableCell>
                            <asp:Table ID="Table3" width="800" HorizontalAlign="Center" runat="server">
                                <asp:TableRow HorizontalAlign="Right">
                                    <asp:TableCell>
                                   <uc1:WebUserControl3 ID="WebUserControl31" runat="server" />                                    </asp:TableCell>                                
                                </asp:TableRow>                                                                                    
                            </asp:Table>                                                                                                                        
                        </asp:TableCell>                    
                    </asp:TableRow>                                                                                                    
                </asp:Table>                        
            </asp:TableCell>                
        </asp:TableRow>            
    </asp:Table>
</body>
</html>

Open in new window

0
 

Author Comment

by:OB1Canobie
ID: 24835030
jinal:

I understand what you suggested, but what I am trying to accomplish is have one menu file as an include where I can edit in one place and all web pages are effected.  If I use the webcontrol method, if I make a change in the menu, I would have to change all pages in the site, and currently there are over 100.  Any other ideas of how accomplish what I am attempting?
0
 
LVL 15

Expert Comment

by:jinal
ID: 24835039
Hello ,

I am not understanding what you are saying ?
If you create one user control . then you put that control on 100 pages. Now you made changes to UserControl than it automatically reflect in all pages.
0
 

Author Closing Comment

by:OB1Canobie
ID: 31602596
jinal: Thanks for your help.  The code worked great.
0

Featured Post

DevOps Toolchain Recommendations

Read this Gartner Research Note and discover how your IT organization can automate and optimize DevOps processes using a toolchain architecture.

Question has a verified solution.

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

Preface In the first article: A Better Website Login System (http://www.experts-exchange.com/A_2902.html) I introduced the EE Collaborative Login System and its intended purpose. In this article I will discuss some of the design consideratio…
JavaScript has plenty of pieces of code people often just copy/paste from somewhere but never quite fully understand. Self-Executing functions are just one good example that I'll try to demystify here.
Viewers will learn about basic arrays, how to declare them, and how to use them. Introduction and definition: Declare an array and cover the syntax of declaring them: Initialize every index in the created array: Example/Features of a basic arr…
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…

770 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