【发布时间】:2020-06-09 00:15:41
【问题描述】:
所以我有一个带有私有方法的类,我想将一个变量从一种方法使用到另一种方法。 我不知道如何以及从哪里开始。 我应该使用 get 和 set 还是创建一个完整的公共方法,我不知道。
这是第一种方法,我想使用变量“prixTotal”
private string RecupPrixTransaction(XmlDocument doc)
{
XmlNodeList nl = null;
XmlNode nodeDevise = null;
string data = string.Empty;
string devise = string.Empty;
decimal acompteTotal = 0;
decimal prixTotal = 0;
if (doc == null)
return (data);
nodeDevise = doc.SelectSingleNode("/Caddie/GroupesProduits/GroupeProduit[@IdGroupe='" + this.guid + "']/Devise");
if (nodeDevise == null)
return (data);
devise = nodeDevise.InnerText;
nl = doc.SelectNodes("/Caddie/GroupesProduits/GroupeProduit[@IdGroupe='" + this.guid + "']/Produits/Produit");
if (nl == null)
return (data);
try
{
foreach (XmlNode nd in nl)
{
prixTotal += decimal.Parse(nd["PrixTotal"].InnerText, System.Globalization.CultureInfo.InvariantCulture.NumberFormat);
acompteTotal += decimal.Parse(nd["AcompteTotal"].InnerText, System.Globalization.CultureInfo.InvariantCulture.NumberFormat);
}
data += "Prix total de la transaction: <strong>" + prixTotal + "</strong> " + devise + "<br />";
data += "Acompte total payé: <strong>" + acompteTotal + "</strong> " + devise + "<br />";
}
catch (Exception)
{
data += "Prix/acompte invalide.<br />";
}
return (data);
}
这是我想使用变量“prixTotal”的方法
private void AffTransa(string id, SqlConnection sqlConnect)
{
SqlDataReader reader = null;
decimal recapPrixTotal = RecupPrixTransaction(prixTotal);
reader = Database.ExecuteReader(EnumConstant.SqlLecture + "SELECT * FROM transactionfin WHERE IdTransactionFin='" + id + "'", sqlConnect);
if (reader.Read())
{
this.lTransa.Text = "<h2>Détail de la transaction " + id + "</h2><br />";
this.lTransa.Text += "Date de la transaction: <b>" + reader["TransactionFinDate"] + "</b><br />";
this.date = reader["TransactionFinDate"].ToString();
this.lTransa.Text += "Solution de paiement: <b>" + MyRegex.ReplacePaiementSol(reader["PaiementSolution_IdPaiementSolution"].ToString()) + "</b><br />";
this.lTransa.Text += "{[{-}]}Mode: <b>" + MyRegex.ReplaceMode(reader["TransactionFinMode"].ToString()) + "</b><br />";
this.lTransa.Text += "Etat: <b>" + MyRegex.ReplaceEtat(reader["TransactionFinEtat"].ToString()) + "</b><br />";
if (reader["TransactionFinUrlRetour"].ToString() != " ")
this.lTransa.Text += "Url de retour: <a href=\"" + reader["TransactionFinUrlRetour"].ToString() + "\">" + MyRegex.ReplaceUrlRetour(reader["TransactionFinUrlRetour"].ToString()) + "</a><br />";
this.lTransa.Text += "<br /><br />Id Transaction: <b>" + reader["TransactionFinIdTransaction"] + "</b><br />";
this.lTransa.Text += "Guid: <b>" + reader["TransactionFinGuidGroupe"].ToString() + "</b><br />";
this.guid = reader["TransactionFinGuidGroupe"].ToString();
this.lTransa.Text += "Id action contact: <b>" + reader["ActionContact_IdActionContact"] + "</b><br />";
this.lTransa.Text += "Id vente entete: <b>" + reader["VenteEntete_IdVenteEntete"] + "</b><br />";
if (reader["TransactionFinDetail"] != null && reader["TransactionFinDetail"].ToString() != string.Empty)
{
this.tbTransa.Visible = true;
this.tbTransa.Text = XmlParsing.IndentXml(reader["TransactionFinDetail"].ToString());
this.lRecap.Text += "Recapitulatif de la Transaction : " ;
this.recapTransa.Visible = true;
this.recapTransa.Text += "#Fournisseur" + "\n" +
"#Internaute" + "\n" +
"#Montants" + "\n" + recapPrixTotal +
"#Produits" + "\n" +
"#Suppléments" + "\n";
}
}
reader.Close();
}
我尝试调用这样的方法,但这不起作用
decimal recapPrixTotal = RecupPrixTransaction(prixTotal);
编辑:
在类的顶部,我将变量“prixTotal”像这样放置
public partial class SeeDetail : System.Web.UI.Page
{
private decimal prixTotal = 0;
...
}
我已经从 RecupPrixTransaction 方法中删除了它 Andin AffTransa 方法,我这样称呼它
decimal recapPrixTotal = prixTotal;
在 RecupPrixTransaction 方法中,“prixTotal”的结果是好的 但在 AffTransa 方法中,数字始终为 0
感谢您的帮助;)
【问题讨论】:
-
什么是
prixTotal?是XmlDocument,因为这是它所期待的 -
这两个方法是同一个类吗?
-
prixTotal 来自 XML 是的
-
是的,这两个方法都在同一个类中
-
当你调用这个方法时说。
标签: c# asp.net .net methods private