Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

Sujet : Problème de Menu [ Archives ASP & ASP.NET / AU SECOURS !!!! ] (GPare)

mercredi 16 juin 2004 à 13:18:00 | Problème de Menu

GPare

Membre Club

Bonjour à tous,

Je suis en train de créer un menu en ASP.Net, seulement voilà j'ai un petit problème.
Lorsque je navique dans le premier niveau pas de problème, lorsque je clique sur un élément j'arrive au deuxième niveau.

Par contre lorsque je clique sur un élément du deuxième niveau, il me reset ma page.

Quelqu'un aurait une idée ?

Voici mon code :



using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Xml;
using System.IO;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

namespace portal305
{
/// <summary>
/// Summary description for menu.
/// </summary>
public class menu : System.Web.UI.Page



{




protected System.Web.UI.WebControls.Table Tmenu;
protected DataSet MyDataSet;
protected XmlDataDocument MyXmlData;


#region Modification Objet Button
protected class MenuButton : Button
{
private string Link;
private int Id;
private string Titre;

public string LinkProperties
{
get
{
return Link;
}
set
{
Link = value;
}
}
public int IdProperties
{
get
{
return Id;
}
set
{
Id = value;
}
}

public string TitreProperties
{
get
{
return Titre;
}
set
{
Titre = value;
}
}
}



#endregion


#region Procédures de test accès XML

private void DisplayTableStructure()
{
Response.Write("<br>Table structure <br>");
Response.Write("Tables count=" + MyXmlData.DataSet.Tables.Count.ToString());
for (int i = 0; i < MyXmlData.DataSet.Tables.Count; i++)
{
Response.Write("<br>TableName='" + MyXmlData.DataSet.Tables[i].TableName + "'.");
Response.Write("<br>Columns count=" + MyXmlData.DataSet.Tables[i].Columns.Count.ToString());

for (int j = 0; j < MyXmlData.DataSet.Tables[i].Columns.Count; j++)
{
Response.Write("<br><br>ColumnName='" +
MyXmlData.DataSet.Tables[i].Columns[j].ColumnName + "', type = "
+ MyXmlData.DataSet.Tables[i].Columns[j].DataType.ToString());
}
}
}


private void DisplayTables()
{
// Navigate MyDataSet
Response.Write("Content of Tables ...\r\n");

foreach(DataTable table in MyDataSet.Tables)
{
Response.Write("TableName = " + table.TableName);
Response.Write ( "<br>---------");
Response.Write("<br>Columns ...<BR>");

foreach(DataColumn column in table.Columns)
{
Response.Write("<BR>" + column.ColumnName);
}
Response.Write("<br>");
Response.Write("<br>Number of rows = " + table.Rows.Count.ToString());
Response.Write("Rows ...<br>");

foreach(DataRow row in table.Rows)
{
foreach(Object value in row.ItemArray)
{
Response.Write(value.ToString() + "<br>");
}
Response.Write("<br>");
}
Response.Write("<br>");
}
}

#endregion

// Chargement des datas à partir du fichier Xml et du fichier de schéma
private DataSet LoadData()

{
const string document = "menu.xml";
const string myLoadSchema = "menu.xsd";
MyXmlData = new XmlDataDocument();
StreamReader MyReader = new StreamReader(Server.MapPath(myLoadSchema) );
MyXmlData.DataSet.ReadXmlSchema(MyReader);
MyReader.Close();

MyXmlData.Load(Server.MapPath(document));

return MyXmlData.DataSet;
}

// Procédure de céation du titre
private void LoadTitle(string t )
{
TableRow TRow = new TableRow();
TableCell TCell = new TableCell();

System.Web.UI.WebControls.Label CLabel = new System.Web.UI.WebControls.Label();
CLabel.Text = t;
CLabel.Font.Bold = true;

CLabel.Font.Name = "Bookman Old Style";
CLabel.ForeColor = Color.White;

CLabel.Font.Size = FontUnit.Small;
TCell = new TableCell();
TCell.Controls.Add(CLabel);
TCell.HorizontalAlign = HorizontalAlign.Center;
TCell.Height = Unit.Percentage(100);
TCell.Width = Unit.Percentage(100);
TCell.BackColor = Color.FromName("#993300");
TRow.Height = Unit.Point(40);
TRow.Cells.Add(TCell);
Tmenu.Rows.Add(TRow);

}


private void LoadMenu( int prev, string titre)
{
TableCell TCell;
TableRow TRow;
Control TControl;
Tmenu.Rows.Clear();

//Création d'un bouton retour ) la page d'acceuil si on n'y est pas
if (prev != 0 )
{
TRow = new TableRow();
TCell = new TableCell();
TControl = new MenuButton();
TCell.BackColor = Color.FromName("#993300");
((MenuButton)TControl).Text = "Acceuil";
((MenuButton)TControl).BackColor = Color.FromName("#993300");
((MenuButton)TControl).BorderStyle = BorderStyle.None;
((MenuButton)TControl).Font.Bold = true;
((MenuButton)TControl).ForeColor = Color.White;
((MenuButton)TControl).Font.Size = FontUnit.Small;
((MenuButton)TControl).Font.Name = "Bookman Old Style";
((MenuButton)TControl).Font.Underline = false;
((MenuButton)TControl).Click += new EventHandler(menu_Click);
((MenuButton)TControl).LinkProperties="";
((MenuButton)TControl).IdProperties = 0;
((MenuButton)TControl).TitreProperties = "Menu";
((MenuButton)TControl).Width = Unit.Percentage(100);
TCell.Controls.Add(TControl);
TCell.Height = Unit.Percentage(100);
TCell.HorizontalAlign = HorizontalAlign.Center;
TCell.Width = Unit.Percentage(100);
TRow.Cells.Add(TCell);
TRow.Height = Unit.Point(20);
Tmenu.Rows.Add(TRow);

}
// Création du titre du menu
LoadTitle(titre);


foreach ( DataRow MyRow in MyDataSet.Tables["structmenu"].Rows)
{

// Insertion des menus si le précédent est correct.

if ( MyRow["Previous"].ToString() == prev.ToString())
{

TRow = new TableRow();
TCell = new TableCell();
TControl = new MenuButton();
TCell.BackColor = Color.FromName("#993300");
((MenuButton)TControl).Text = MyRow["Name"].ToString();
((MenuButton)TControl).BackColor = Color.FromName("#993300");
((MenuButton)TControl).BorderStyle = BorderStyle.None;
((MenuButton)TControl).ForeColor = Color.White;
((MenuButton)TControl).Font.Size = FontUnit.Small;
((MenuButton)TControl).Font.Name = "Bookman Old Style";
((MenuButton)TControl).Font.Underline = false;
((MenuButton)TControl).LinkProperties=MyRow["Link"].ToString();
((MenuButton)TControl).IdProperties = Convert.ToInt32(MyRow["Id"]);
((MenuButton)TControl).TitreProperties = MyRow["Name"].ToString();
((MenuButton)TControl).Width = Unit.Percentage(100);
((MenuButton)TControl).Click += new EventHandler(menu_Click);
TCell.Controls.Add(TControl);
TCell.Height = Unit.Percentage(100);
TCell.HorizontalAlign = HorizontalAlign.Center;
TCell.Width = Unit.Percentage(100);
TRow.Cells.Add(TCell);
TRow.Height = Unit.Point(20);
Tmenu.Rows.Add(TRow);

}
}
}

// Procédure lors du Clic sur un bouton du menu

protected void menu_Click(object sender, EventArgs e)
{
if (((MenuButton)sender).LinkProperties.Length == 0)
{
LoadMenu(((MenuButton)sender).IdProperties, ((MenuButton)sender).TitreProperties);
Response.Write("OK<br>");
}
else
{

}



}

private void Page_Load(object sender, System.EventArgs e)
{

// Put user code to initialize the page here

MyDataSet = LoadData();
//DisplayTableStructure();
//DisplayTables();

LoadMenu(0,"Menu");

}






#region Web Form Designer generated code
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: This call is required by the ASP.NET Web Form Designer.
//
InitializeComponent();
base.OnInit(e);
}

/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);

}
#endregion


}
}





Gaetan is there, the show must go on



Cette discussion est classé dans : system, response, tcell, menubutton, tcontrol


Répondre à ce message

Sujets en rapport avec ce message

besoin d'aide ! newbie ! [ par Larwin ] bonjour tout le monde...nouveau depuis hier soir dans le monde asp .net, et j'ai déja besoin d'aide !je code déja depuis un certain temps en vb.net et Probleme d'accent lors de l'export de données sur excel [ par porgy ] J'ai besoin d'exporter un datagrid vers excel. J'utilise le code suivant que j'ai trouvé sur le net. mais lorsque j'ai des accent dans mon datagrid, l Base de Donée : Erreur ! [ par Pierrrot ] Bonjour,Grace a mon code je suis sensé faire un enregistrement dans une base de donnée.Par contre, la page aspx n'accepte que les chiffres ce qui est Recherche dans un catalogue Index Server [ par sisi187 ] Hello, Je suis entrain de d'essayer de faire des requetes dans un catalogue index server se trouvant dans le répertoire C:/inetpub/catalog.wci. j'ai aide code asp urgent ! [ par tommie ] bonjour a tous,Dans une page je vais afficher les questionnaires des enfants a impimerEt pour chaque questionnaire je met des infos les concernantMais affichage dans deux colonnes [ par rkarrer74 ] Bonjour :) Voila j'ai une db de laquelle j'extrait des valeurs. Mon problème est que je souhaite afficher ces valeur sur deux colonnes Il s'agit d'un Caractère "+" (%2b) dans une url [ par TheSaib ] Bonjour à tous :)J'ai un problème pour récuperer un numéro de teléphone passer dans l'url de mon GET :page.aspx?P1=%2b33123456789J'ai essayé avec urld Lister les fichier d'un disque dur et faire correspondre le fichier [ par pierre1256 ] Voila je m'explique, je liste le contenu d'un disque dur situé sur le serveur avec ce code : dim File_system, FolderSet File_system = CreateObject("Sc ArrayList en c# [ par Jackboy ] Salut !J'aimerai afficher les valeur de mon ArrayList. Sous msdn il indique la methode Item, donc je passe ceci dans mon response.write et rien a fair Connexion SQL Server [ par drahcir ] Salut à tous,voilà, je viens du vb.net, et je doit développer une page web en asp.net. Pour se faire, j'ai besoin de me connecter à une base de donnée


Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,281 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.