ASP.NET程序中常用的三十三种代码(23-28)
23.在DataGrid中有3个模板列包含Textbox分别为 DG_ShuLiang (数量) DG_DanJian(单价) DG_JinE(金额)分别在5.6.7列,要求在录入数量及单价的时候自动算出金额即:数量*单价=金额还要求录入时限制为 数值型.我如何用客户端脚本实现这个功能?
〖思归〗
 <asp:TemplateColumn HeaderText="数量">
<asp:TemplateColumn HeaderText="数量"> 
 <ItemTemplate>
<ItemTemplate>
 <asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’
<asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’ 
 onkeyup="javascript:DoCal()"
onkeyup="javascript:DoCal()"
 />
/>

 <asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^\d+$" />
<asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^\d+$" />
 </ItemTemplate>
</ItemTemplate>
 </asp:TemplateColumn>
</asp:TemplateColumn>

 <asp:TemplateColumn HeaderText="单价">
<asp:TemplateColumn HeaderText="单价"> 
 <ItemTemplate>
<ItemTemplate>
 <asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’
<asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’ 
 onkeyup="javascript:DoCal()"
onkeyup="javascript:DoCal()"
 />
/>

 <asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^\d+(\.\d*)?$" />
<asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^\d+(\.\d*)?$" />

 </ItemTemplate>
</ItemTemplate>
 </asp:TemplateColumn>
</asp:TemplateColumn>

 <asp:TemplateColumn HeaderText="金额">
<asp:TemplateColumn HeaderText="金额"> 
 <ItemTemplate>
<ItemTemplate>
 <asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />
<asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />
 </ItemTemplate>
</ItemTemplate>
 </asp:TemplateColumn><script language="javascript">
</asp:TemplateColumn><script language="javascript">
 function DoCal()
function DoCal()
 {
{
 var e = event.srcElement;
 var e = event.srcElement;
 var row = e.parentNode.parentNode;
 var row = e.parentNode.parentNode;
 var txts = row.all.tags("INPUT");
 var txts = row.all.tags("INPUT");
 if (!txts.length || txts.length < 3)
 if (!txts.length || txts.length < 3)
 return;
  return;

 var q = txts[txts.length-3].value;
 var q = txts[txts.length-3].value;
 var p = txts[txts.length-2].value;
 var p = txts[txts.length-2].value;

 if (isNaN(q) || isNaN(p))
 if (isNaN(q) || isNaN(p))
 return;
  return;

 q = parseInt(q);
 q = parseInt(q);
 p = parseFloat(p);
 p = parseFloat(p);

 txts[txts.length-1].value = (q * p).toFixed(2);
 txts[txts.length-1].value = (q * p).toFixed(2);
 }
}
 </script>
</script>

24.datagrid选定比较底下的行时,为什么总是刷新一下,然后就滚动到了最上面,刚才选定的行因屏幕的关系就看不到了。
 page_load
page_load 
 page.smartNavigation=true
page.smartNavigation=true
 25.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小 ?
 25.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小 ? 
 private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
 {
{
 for(int i=0;i<e.Item.Cells.Count-1;i++)
 for(int i=0;i<e.Item.Cells.Count-1;i++)
 if(e.Item.ItemType==ListItemType.EditType)
  if(e.Item.ItemType==ListItemType.EditType)
 {
  {
 e.Item.Cells[i].Attributes.Add("Width", "80px")
   e.Item.Cells[i].Attributes.Add("Width", "80px")
 }
  } 
 }
}

26.对话框
 private static string ScriptBegin = "<script language=\"JavaScript\">";
private static string ScriptBegin = "<script language=\"JavaScript\">";
 private static string ScriptEnd = "</script>";
private static string ScriptEnd = "</script>";

 public static void ConfirmMessageBox(string PageTarget,string Content)
public static void ConfirmMessageBox(string PageTarget,string Content)
 {
{
 string ConfirmContent="var retValue=window.confirm(’"+Content+"’);"+"if(retValue){window.location=’"+PageTarget+"’;}";
 string ConfirmContent="var retValue=window.confirm(’"+Content+"’);"+"if(retValue){window.location=’"+PageTarget+"’;}";

 ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;
 ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;

 Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler;
 Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler;
 ParameterPage.RegisterStartupScript("confirm",ConfirmContent);
 ParameterPage.RegisterStartupScript("confirm",ConfirmContent);
 //Response.Write(strScript);
 //Response.Write(strScript);
 }
}

27. 将时间格式化:string aa=DateTime.Now.ToString("yyyy年MM月dd日");
1.1 取当前年月日时分秒
 currentTime=System.DateTime.Now;
currentTime=System.DateTime.Now;

1.2 取当前年
 int 年= DateTime.Now.Year;
int 年= DateTime.Now.Year;
 1.3 取当前月
1.3 取当前月 
 int 月= DateTime.Now.Month;
int 月= DateTime.Now.Month; 

1.4 取当前日
 int 日= DateTime.Now.Day;
int 日= DateTime.Now.Day; 
 1.5 取当前时
1.5 取当前时 
 int 时= DateTime.Now.Hour;
int 时= DateTime.Now.Hour; 
 1.6 取当前分
1.6 取当前分 
 int 分= DateTime.Now.Minute;
int 分= DateTime.Now.Minute; 
 1.7 取当前秒
 1.7 取当前秒 
 int 秒= DateTime.Now.Second;
int 秒= DateTime.Now.Second; 

1.8 取当前毫秒
 int 毫秒= DateTime.Now.Millisecond;
int 毫秒= DateTime.Now.Millisecond; 
 28.自定义分页代码:
28.自定义分页代码:
先定义变量 :
 public static int pageCount; //总页面数
public static int pageCount; //总页面数 
 public static int curPageIndex=1; //当前页面
public static int curPageIndex=1; //当前页面 
 下一页:
下一页: 
 if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1))
if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1)) 
 {
{ 
 DataGrid1.CurrentPageIndex += 1;
 DataGrid1.CurrentPageIndex += 1; 
 curPageIndex+=1;
 curPageIndex+=1; 
 }
} 

 bind(); // DataGrid1数据绑定函数
bind(); // DataGrid1数据绑定函数 

上一页:
 if(DataGrid1.CurrentPageIndex >0)
if(DataGrid1.CurrentPageIndex >0) 
 {
{ 
 DataGrid1.CurrentPageIndex += 1;
 DataGrid1.CurrentPageIndex += 1; 
 curPageIndex-=1;
 curPageIndex-=1; 
 }
} 

 bind(); // DataGrid1数据绑定函数
bind(); // DataGrid1数据绑定函数 

直接页面跳转:
 int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值
int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值 

 if(a<DataGrid1.PageCount)
if(a<DataGrid1.PageCount) 
 {
{ 
 this.DataGrid1.CurrentPageIndex=a;
 this.DataGrid1.CurrentPageIndex=a; 
 }
} 

 bind();
bind(); 
 
〖思归〗
 <asp:TemplateColumn HeaderText="数量">
<asp:TemplateColumn HeaderText="数量">  <ItemTemplate>
<ItemTemplate> <asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’
<asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’  onkeyup="javascript:DoCal()"
onkeyup="javascript:DoCal()" />
/>
 <asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^\d+$" />
<asp:RegularExpressionValidator id="revS" runat="server" ControlToValidate="ShuLiang" ErrorMessage="must be integer" ValidationExpression="^\d+$" /> </ItemTemplate>
</ItemTemplate> </asp:TemplateColumn>
</asp:TemplateColumn>
 <asp:TemplateColumn HeaderText="单价">
<asp:TemplateColumn HeaderText="单价">  <ItemTemplate>
<ItemTemplate> <asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’
<asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’  onkeyup="javascript:DoCal()"
onkeyup="javascript:DoCal()" />
/>
 <asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^\d+(\.\d*)?$" />
<asp:RegularExpressionValidator id="revS2" runat="server" ControlToValidate="DanJian" ErrorMessage="must be numeric" ValidationExpression="^\d+(\.\d*)?$" />
 </ItemTemplate>
</ItemTemplate> </asp:TemplateColumn>
</asp:TemplateColumn>
 <asp:TemplateColumn HeaderText="金额">
<asp:TemplateColumn HeaderText="金额">  <ItemTemplate>
<ItemTemplate> <asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />
<asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ /> </ItemTemplate>
</ItemTemplate> </asp:TemplateColumn><script language="javascript">
</asp:TemplateColumn><script language="javascript"> function DoCal()
function DoCal() {
{ var e = event.srcElement;
 var e = event.srcElement; var row = e.parentNode.parentNode;
 var row = e.parentNode.parentNode; var txts = row.all.tags("INPUT");
 var txts = row.all.tags("INPUT"); if (!txts.length || txts.length < 3)
 if (!txts.length || txts.length < 3) return;
  return;
 var q = txts[txts.length-3].value;
 var q = txts[txts.length-3].value; var p = txts[txts.length-2].value;
 var p = txts[txts.length-2].value;
 if (isNaN(q) || isNaN(p))
 if (isNaN(q) || isNaN(p)) return;
  return;
 q = parseInt(q);
 q = parseInt(q); p = parseFloat(p);
 p = parseFloat(p);
 txts[txts.length-1].value = (q * p).toFixed(2);
 txts[txts.length-1].value = (q * p).toFixed(2); }
} </script>
</script>
24.datagrid选定比较底下的行时,为什么总是刷新一下,然后就滚动到了最上面,刚才选定的行因屏幕的关系就看不到了。
 page_load
page_load  page.smartNavigation=true
page.smartNavigation=true
 private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e) {
{ for(int i=0;i<e.Item.Cells.Count-1;i++)
 for(int i=0;i<e.Item.Cells.Count-1;i++) if(e.Item.ItemType==ListItemType.EditType)
  if(e.Item.ItemType==ListItemType.EditType) {
  { e.Item.Cells[i].Attributes.Add("Width", "80px")
   e.Item.Cells[i].Attributes.Add("Width", "80px") }
  }  }
}
26.对话框
 private static string ScriptBegin = "<script language=\"JavaScript\">";
private static string ScriptBegin = "<script language=\"JavaScript\">"; private static string ScriptEnd = "</script>";
private static string ScriptEnd = "</script>";
 public static void ConfirmMessageBox(string PageTarget,string Content)
public static void ConfirmMessageBox(string PageTarget,string Content) {
{ string ConfirmContent="var retValue=window.confirm(’"+Content+"’);"+"if(retValue){window.location=’"+PageTarget+"’;}";
 string ConfirmContent="var retValue=window.confirm(’"+Content+"’);"+"if(retValue){window.location=’"+PageTarget+"’;}";
 ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;
 ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;
 Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler;
 Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler; ParameterPage.RegisterStartupScript("confirm",ConfirmContent);
 ParameterPage.RegisterStartupScript("confirm",ConfirmContent); //Response.Write(strScript);
 //Response.Write(strScript); }
}
27. 将时间格式化:string aa=DateTime.Now.ToString("yyyy年MM月dd日");
1.1 取当前年月日时分秒
 currentTime=System.DateTime.Now;
currentTime=System.DateTime.Now;
1.2 取当前年
 int 年= DateTime.Now.Year;
int 年= DateTime.Now.Year;
 int 月= DateTime.Now.Month;
int 月= DateTime.Now.Month; 
1.4 取当前日
 int 日= DateTime.Now.Day;
int 日= DateTime.Now.Day; 
 int 时= DateTime.Now.Hour;
int 时= DateTime.Now.Hour; 
 int 分= DateTime.Now.Minute;
int 分= DateTime.Now.Minute; 
 int 秒= DateTime.Now.Second;
int 秒= DateTime.Now.Second; 
1.8 取当前毫秒
 int 毫秒= DateTime.Now.Millisecond;
int 毫秒= DateTime.Now.Millisecond; 
先定义变量 :
 public static int pageCount; //总页面数
public static int pageCount; //总页面数  public static int curPageIndex=1; //当前页面
public static int curPageIndex=1; //当前页面 
 if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1))
if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1))  {
{  DataGrid1.CurrentPageIndex += 1;
 DataGrid1.CurrentPageIndex += 1;  curPageIndex+=1;
 curPageIndex+=1;  }
} 
 bind(); // DataGrid1数据绑定函数
bind(); // DataGrid1数据绑定函数 
上一页:
 if(DataGrid1.CurrentPageIndex >0)
if(DataGrid1.CurrentPageIndex >0)  {
{  DataGrid1.CurrentPageIndex += 1;
 DataGrid1.CurrentPageIndex += 1;  curPageIndex-=1;
 curPageIndex-=1;  }
} 
 bind(); // DataGrid1数据绑定函数
bind(); // DataGrid1数据绑定函数 
直接页面跳转:
 int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值
int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值 
 if(a<DataGrid1.PageCount)
if(a<DataGrid1.PageCount)  {
{  this.DataGrid1.CurrentPageIndex=a;
 this.DataGrid1.CurrentPageIndex=a;  }
} 
 bind();
bind(); 
 
                    
                

 
   
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号