- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在做一个项目,我想生成一个包含三份副本的收据 - 学生副本,帐户副本,办公室副本。所有这些副本将具有相同的数据,除了标题。所以我所做的是生成一个面板并填充它并为三个副本制作了三个不同的 div。现在在填充面板后的后端,我在运行时制作了三个具有不同名称的面板并将该面板传递给它们,然后将这三个面板添加到它们各自的 div。通过这样做我只收到一次收据,而且是在最后一个 div 中。请帮助我如何实现这一点。
代码
public void generatereceipt()
{ //pnlreceipt is the main panel built in aspx page
divstudent.Controls.Add(pnlreceipt);
divpnlreceipt.Visible = true;
divstudent.Visible = true;
divoffice.Visible = true;
divaccounts.Visible = true;
Panel pnlstudent = new Panel();
pnlstudent = pnlreceipt;
divstudent.Controls.Add(pnlstudent);
Panel pnloffice = new Panel();
pnloffice = pnlreceipt;
divoffice.Controls.Add(pnloffice);
Panel pnlaccounts = new Panel();
pnlaccounts = pnlreceipt;
divaccounts.Controls.Add(pnlaccounts);
divoffice.Visible = true;
divaccounts.Visible = true;
}
//method to fill my panel receipt
public void filldata()
{
sql ="select s.admissionnumber,s.studentname,g.forename,g.relationshipcode,c.classname,concat(a.address,',',a.town,',',a.state,',',a.country) as address,e.amount "
+"from tblstudent s left join tblguardian g on s.studentcode=g.studentcode "
+"left join tblclass c on c.classcode=s.classcode "
+"left join tblcontactaddress ca on ca.usercode=g.guardiancode "
+"left join tbladdress a on ca.addressid=a.addressid "
+"left join tblmiddaymeal_entry e on e.studentcode=s.studentcode "
+"where s.studentcode='"+drpstudent.SelectedItem.Value+"' and c.classcode='"+drpclass.SelectedItem.Value+"'";
ds = obj.openDataset(sql,Session["schoolcode"].ToString());
lblfathername.Text = "";
for (int i = 0; i < ds.Tables[0].Rows.Count;i++)
{
if (ds.Tables[0].Rows[0]["relationshipcode"].ToString()=="14")
{
lblfathername.Text = ds.Tables[0].Rows[i]["forename"].ToString();
}
}
string sqlrecepit = "SELECT * FROM tblmiddaymeal_receipt order by receiptno desc";
DataSet dsreceipt = new DataSet();
dsreceipt = obj.openDataset(sqlrecepit,Session["schoolcode"].ToString());
string sqlschool = "select * from tblschool where schoolcode='"+Session["schoolcode"].ToString()+"'";
DataSet dsSchool = new DataSet();
dsSchool = obj.openDataset(sqlschool,Session["schoolcode"].ToString());
if (dsreceipt.Tables[0].Rows.Count == 0)
{
lblreceiptno.Text = "10000";
}
else
{
lblreceiptno.Text = (Convert.ToInt32(dsreceipt.Tables[0].Rows[0]["receiptno"]) + 1).ToString();
}
lblreceiptcopy.Text = "Student Copy";
lbladmno.Text = ds.Tables[0].Rows[0]["admissionnumber"].ToString();
lblcodeno.Text = "";
lbldate.Text = "<b>"+DateTime.Now.ToString("dd/MM/yyyy")+"</b>";
lblname.Text = ds.Tables[0].Rows[0]["studentname"].ToString();
lblclass.Text = ds.Tables[0].Rows[0]["classname"].ToString();
lblmonth.Text = monthdisplay;
lblschool.Text = dsSchool.Tables[0].Rows[0]["schoolname"].ToString();
lblbranch.Text = "S.S.B";
if (ds.Tables[0].Rows[0]["amount"].ToString().Length == 0)
{
lblamount.Text = "";
lbltotalamount.Text = "";
lblamountwords.Text = "";
}
else
{
lblamount.Text = ds.Tables[0].Rows[0]["amount"].ToString();
lbltotalamount.Text = "<b>" + ds.Tables[0].Rows[0]["amount"].ToString() + "</b>";
lblamountwords.Text = " " + "<b>" + NumberToWords(Convert.ToInt32(ds.Tables[0].Rows[0]["amount"])) + " only" + " </b>";
}
lblpaymenttype.Text = drppayment.SelectedItem.Text;
if(drppayment.SelectedIndex==2)
{
lblbankname.Text = txtbankname.Text;
}
string sqlinsert = "insert into tblmiddaymeal_receipt(receiptno,studentcode,date,forMonthOf,branch,amount,paymenttype,bankname) "
+ "values('" + lblreceiptno.Text + "','" + drpstudent.SelectedItem.Value + "','" + DateTime.Now.ToString("dd/MM/yyyy") + "','" + months + "','" + lblbranch.Text + "','" + lblamount.Text + "','" + lblpaymenttype.Text + "','" + lblbankname.Text + "')";
obj.executeQuery(sqlinsert, Session["schoolcode"].ToString());
}
我的面板receipt结构和三个div-student,account,office在aspx页面
<asp:Panel ID="pnlreceipt" runat="server">
<div id="divprint">
<div id="divpnlreceipt" runat="server" visible="false">
<table class="outertable">
<tr>
<td>
<asp:Image ID="imglogo" runat="server" ImageUrl="~/Images/scholar-logo.png" CssClass="logo"/>
<asp:Label ID="lblreceiptcopy" runat="server" Text="Label" CssClass="receiptcopyheading"></asp:Label>
</td>
</tr>
<tr>
<td>
<table class="innertablereceipt">
<tr>
<td colspan="4"><span class="innerheading">ME-LUNCH RECEIPT</span></td>
</tr>
<tr>
<td>
Receipt No:<asp:Label ID="lblreceiptno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Adm. No:<asp:Label ID="lbladmno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td class="col3">
Code No:<asp:Label ID="lblcodeno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Date:<asp:Label ID="lbldate" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Name:<asp:Label ID="lblname" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Class:<asp:Label ID="lblclass" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="2">
For the month of:<asp:Label ID="lblmonth" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Father's Name:<asp:Label ID="lblfathername" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
School:<asp:Label ID="lblschool" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="2">
Branch:<asp:Label ID="lblbranch" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Address:<asp:Label ID="lbladdress" runat="server" Text=""></asp:Label>
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr style="border-bottom:1px dotted black;">
<td colspan="2">
Particulars
</td>
<td>
Amount
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr style="border-bottom:1px dotted black;height:40px">
<td colspan="2">
Me-Lunch Charges
</td>
<td colspan="2">
<asp:Label ID="lblamount" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr>
<td colspan="3"></td>
<td>
Total amount:<asp:Label ID="lbltotalamount" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Cash/cheque No:<asp:Label ID="lblpaymenttype" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="3">
Bank Name:<asp:Label ID="lblbankname" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>(In words):</td>
<td colspan="2" class="txtunderline">
<asp:Label ID="lblamountwords" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td></td>
</tr>
<tr>
<td colspan="3">
*Cheque subject to realisation
</td>
<td>Cashier Signature</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
</div>
</asp:Panel>
<div id="divstudent" runat="server" class="studentreceipt" visible="false">div1</div>
<div id="divoffice" runat="server" class="officereceipt" visible="false">div2</div>
<div id="divaccounts" runat="server" class="accountsreceipt" visible="false">div3</div>
输出我想要的收据
最佳答案
我将我的 pnlreceipt 放在中继器中,它解决了我正在粘贴代码的问题
中继器的aspx代码
<asp:Repeater ID="rptreceipt" runat="server" OnItemDataBound="rptreceipt_OnItemDataBound">
<HeaderTemplate></HeaderTemplate>
<ItemTemplate>
<asp:Panel ID="pnlreceipt" runat="server">
<div runat="server">
<div id="divpnlreceipt" runat="server">
<table id="tblreceipt" class="outertable" runat="server">
<tr>
<td>
<asp:Image ID="imglogo" runat="server" ImageUrl="~/Images/scholar-logo.png" CssClass="logo"/>
<asp:Label ID="lblreceiptcopy" runat="server" Text="Label" CssClass="receiptcopyheading"></asp:Label>
</td>
</tr>
<tr>
<td>
<table class="innertablereceipt">
<tr>
<td colspan="4"><span class="innerheading">ME-LUNCH RECEIPT</span></td>
</tr>
<tr>
<td>
Receipt No:<asp:Label ID="lblreceiptno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Adm. No:<asp:Label ID="lbladmno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td class="col3">
Code No:<asp:Label ID="lblcodeno" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Date:<asp:Label ID="lbldate" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Name:<asp:Label ID="lblname" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
Class:<asp:Label ID="lblclass" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="2">
For the month of:<asp:Label ID="lblmonth" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Father's Name:<asp:Label ID="lblfathername" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td>
School:<asp:Label ID="lblschool" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="2">
Branch:<asp:Label ID="lblbranch" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Address:<asp:Label ID="lbladdress" runat="server" Text=""></asp:Label>
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr style="border-bottom:1px dotted black;">
<td colspan="2">
Particulars
</td>
<td>
Amount
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr style="border-bottom:1px dotted black;height:40px">
<td colspan="2">
Me-Lunch Charges
</td>
<td colspan="2">
<asp:Label ID="lblamount" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr style="height:4px;">
<td colspan="4">................................................................................................................................................................................................</td>
</tr>
<tr>
<td colspan="3"></td>
<td>
Total amount:<asp:Label ID="lbltotalamount" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>
Cash/cheque No:<asp:Label ID="lblpaymenttype" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td colspan="3">
Bank Name:<asp:Label ID="lblbankname" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
</tr>
<tr>
<td>(In words):</td>
<td colspan="2" class="txtunderline">
<asp:Label ID="lblamountwords" runat="server" Text="" CssClass="lblreceipt"></asp:Label>
</td>
<td></td>
</tr>
<tr>
<td colspan="3">
*Cheque subject to realisation
</td>
<td>Cashier Signature</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
</div>
</asp:Panel>
</ItemTemplate>
</asp:Repeater>
C#代码
public void filldata()
{
int[] a=new int[]{0,1,2};
rptreceipt.DataSource = a;
rptreceipt.DataBind();
}
public void rptreceipt_OnItemDataBound(object sender,RepeaterItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
sql = "select s.admissionnumber,s.studentname,g.forename,g.relationshipcode,c.classname,concat(a.address,',',a.town,',',a.state,',',a.country) as address,e.amount "
+ "from tblstudent s left join tblguardian g on s.studentcode=g.studentcode "
+ "left join tblclass c on c.classcode=s.classcode "
+ "left join tblcontactaddress ca on ca.usercode=g.guardiancode "
+ "left join tbladdress a on ca.addressid=a.addressid "
+ "left join tblmiddaymeal_entry e on e.studentcode=s.studentcode "
+ "where s.studentcode='" + drpstudent.SelectedItem.Value + "' and c.classcode='" + drpclass.SelectedItem.Value + "'";
ds = obj.openDataset(sql, Session["schoolcode"].ToString());
Label lblreceiptcopy=(Label) e.Item.FindControl("lblreceiptcopy");
Label lblreceiptno = (Label)e.Item.FindControl("lblreceiptno");
Label lbladmno = (Label)e.Item.FindControl("lbladmno");
Label lblcodeno = (Label)e.Item.FindControl("lblcodeno");
Label lbldate = (Label)e.Item.FindControl("lbldate");
Label lblname = (Label)e.Item.FindControl("lblname");
Label lblclass = (Label)e.Item.FindControl("lblclass");
Label lblmonth = (Label)e.Item.FindControl("lblmonth");
Label lblfathername = (Label)e.Item.FindControl("lblfathername");
Label lblschool = (Label)e.Item.FindControl("lblschool");
Label lblbranch = (Label)e.Item.FindControl("lblbranch");
Label lbladdress = (Label)e.Item.FindControl("lbladdress");
Label lblamount = (Label)e.Item.FindControl("lblamount");
Label lbltotalamount = (Label)e.Item.FindControl("lbltotalamount");
Label lblpaymenttype = (Label)e.Item.FindControl("lblpaymenttype");
Label lblbankname = (Label)e.Item.FindControl("lblbankname");
Label lblamountwords = (Label)e.Item.FindControl("lblamountwords");
if (e.Item.ItemIndex == 0)
lblreceiptcopy.Text = "Student Copy";
else if (e.Item.ItemIndex == 1)
lblreceiptcopy.Text = "Office Copy";
else
lblreceiptcopy.Text = "Accounts Copy";
lblfathername.Text = "";
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
if (ds.Tables[0].Rows[0]["relationshipcode"].ToString() == "14")
{
lblfathername.Text = ds.Tables[0].Rows[i]["forename"].ToString();
}
}
string sqlrecepit = "SELECT * FROM tblmiddaymeal_receipt order by receiptno desc";
DataSet dsreceipt = new DataSet();
dsreceipt = obj.openDataset(sqlrecepit, Session["schoolcode"].ToString());
string sqlschool = "select * from tblschool where schoolcode='" + Session["schoolcode"].ToString() + "'";
DataSet dsSchool = new DataSet();
dsSchool = obj.openDataset(sqlschool, Session["schoolcode"].ToString());
if (dsreceipt.Tables[0].Rows.Count == 0)
{
lblreceiptno.Text = "10000";
}
else
{
lblreceiptno.Text = (Convert.ToInt32(dsreceipt.Tables[0].Rows[0]["receiptno"]) + 1).ToString();
}
//lblreceiptcopy.Text = "Student Copy";
lbladmno.Text = ds.Tables[0].Rows[0]["admissionnumber"].ToString();
lblcodeno.Text = "";
lbldate.Text = "<b>" + DateTime.Now.ToString("dd/MM/yyyy") + "</b>";
lblname.Text = ds.Tables[0].Rows[0]["studentname"].ToString();
lblclass.Text = ds.Tables[0].Rows[0]["classname"].ToString();
lblmonth.Text = monthdisplay;
lblschool.Text = dsSchool.Tables[0].Rows[0]["schoolname"].ToString();
lblbranch.Text = "S.S.B";
if (ds.Tables[0].Rows[0]["amount"].ToString().Length == 0)
{
lblamount.Text = "";
lbltotalamount.Text = "";
lblamountwords.Text = "";
}
else
{
lblamount.Text = ds.Tables[0].Rows[0]["amount"].ToString();
lbltotalamount.Text = "<b>" + ds.Tables[0].Rows[0]["amount"].ToString() + "</b>";
lblamountwords.Text = " " + "<b>" + NumberToWords(Convert.ToInt32(ds.Tables[0].Rows[0]["amount"])) + " only" + " </b>";
}
lblpaymenttype.Text = drppayment.SelectedItem.Text;
if (drppayment.SelectedIndex == 2)
{
lblbankname.Text = txtbankname.Text;
}
string sqlinsert = "insert into tblmiddaymeal_receipt(receiptno,studentcode,date,forMonthOf,branch,amount,paymenttype,bankname) "
+ "values('" + lblreceiptno.Text + "','" + drpstudent.SelectedItem.Value + "','" + DateTime.Now.ToString("dd/MM/yyyy") + "','" + months + "','" + lblbranch.Text + "','" + lblamount.Text + "','" + lblpaymenttype.Text + "','" + lblbankname.Text + "')";
obj.executeQuery(sqlinsert, Session["schoolcode"].ToString());
}
}
关于c# - 复制面板及其所有控件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21746682/
我有一个 Bootstrap 面板,里面有另一个面板。两者在面板标题中都有一个字形图标。默认情况下,面板是折叠的。当面板折叠时,将设置 glyphicon-unchecked。当我点击这个字形图标时,
使用 Grafana 时,我们会在某些电视上使用它。有谁知道制作它的方法,如果有人添加面板,更改布局等,它不仅会自动刷新数据,还会自动刷新实际仪表板? 我们真的厌倦了不断要求具有远程访问权限的人登录并
基本上,我试图让屏幕底部有 3 个按钮,然后在屏幕中间有一个包含文字的标签。但是,我似乎无法同时在 GUI 中同时拥有按钮和标签。我是一名初学者,对布局了解不多(即使我已经阅读过它们),因此任何帮助/
作为学校的类(class)作业,我们必须提出一个自定义项目,我选择了一个原本打算在 ActionScript 上编写的游戏创意,但决定在 Java 上插入它。最初进展顺利,游戏代码正常运行, Spri
我正在尝试使用 Java Graphics 制作一个生命模拟游戏,但是当运行我的代码时,屏幕的左侧三分之一是灰色的。我希望整个屏幕是白色的,黑色方 block 代表生命方 block 。我对所有 ja
下面是动态驱动的一个不错的“下拉面板”。 http://www.dynamicdrive.com/dynamicindex17/dddropdownpanel.htm 如您所见,它是一个面板,在打开时
所以我有这个函数 onDisplayError ,如果请求失败,每次都会调用它。这意味着如果用户按下保存按钮并且 3 个请求失败,我当前会收到 3 个弹出消息。我的目标是此函数检查我的弹出窗口是否已打
我正在尝试为我的一个类(class)制作一款游戏,但在实现一些我想做的事情时遇到了麻烦。本质上,我希望在同一个图形用户界面窗口中包含多个不同的部分。 据我了解,我会使用 JPanel 来创建这些不同的
我目前正在测试这种类型的面板 jquery: http://codyhouse.co/gem/css-slide-in-panel/ 但是当我想检测从顶部滚动以显示一个 div 时:没办法:( 一种检
我可能正在搜索错误的问题,但我找不到这个问题的答案。 我有一个 AutoScroll 设置为 true 的面板。控件动态添加到面板。我需要在滚动条可见时触发一个事件,但我找不到这样的事件。 如有任何建
我有一堆 Bootstrap 面板,其中一些是相互关联的。有点像 Panel A -> Panel B -> Panel C 当用户单击面板 B 时,将显示面板 C,当单击面板 C 时,将显示面板 D
我正在尝试开发一种带有指标的下拉列表,并相应地针对应该出现在仪表板上的选定指标特定面板。反之亦然,如果未选择指标,则面板应隐藏。 我找到了链接 http://search-devops.com/m/k
我有一个窗口,窗口里面有面板。我动态地向面板添加组件。这些组件采用“hbox”布局,以便它们水平排列。单击按钮后,我将在“hbox”布局中再向面板添加一行类似组件。这里的问题是我想在第一行下面添加第二
我使用 jQuery Accordion 将表单拆分为多个面板,并使用 jQuery 验证来检查所需字段。只要验证字段位于打开的面板中,它就可以很好地显示已验证字段中的错误。 举个例子。假设我有三个
我正在尝试检查我的面板是打开还是关闭。 我尝试过这样的: $(document).on('open', '.ui-panel', function(){ console.log('open');
我有一个面板,我想将其 float 在所有窗口之上并出现在所有空间中。这可以通过 轻松完成 [self.panel setLevel:kCGUtilityWindowLevel]; [self.win
我想在格子中的单个面板上叠加多个组,并且想要独立的回归线。 获得多个面板相当容易,每个面板都有一条使用条件因子的回归线: xyplot( Petal.Width ~ Petal.Length |
Delphi 有滑动(动画)面板组件吗? 例如可以在 Raize Components 中找到它(带有“热点”或隐藏/显示按钮的左侧面板)。 我不需要一个可调整大小的面板,而是一个可以从左向右水平平滑
我有一个 Bootstrap Accordion : 我想禁用非事件面板中的所有输入控件。仅验证事件面板。 我有一个检测事件选项卡的功能: $(".panel").on("show.bs.collap
我正在尝试将组件放入不同尺寸的面板中。但是,我意识到 GridLayout 将大小相同的部分分开。如何实现如下图所示 enter image description here import java.
我是一名优秀的程序员,十分优秀!