ASP.NET Web开发实用代码举例(三)

转帖|其它|编辑:郝浩|2009-01-19 10:47:52.000|阅读 976 次

概述:ASP.NET Web开发实用代码举例(三)

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

文章关键字:|ASP.NET|Web|开发|代码|举例|DataGrid|控件|编辑|文本框|服务器|

1.读取DataGrid控件TextBox值

foreach(DataGrid dgi in yourDataGrid.Items)
{
    TextBox tb = (TextBox)dgi.FindControl("yourTextBoxId");
    tb.Text....
}

2.在DataGrid中有3个模板列包含Textbox分别为DG_ShuLiang (数量)、DG_DanJian(单价) 、DG_JinE(金额),分别在5、6、7列,要求在录入数量及单价的时候自动算出金额即:数量*单价=金额。还要求录入时限制为数值型。我如何用客户端脚本实现这个功能?

<asp:TemplateColumn HeaderText="数量"> 
<ItemTemplate>
<asp:TextBox id="ShuLiang" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_ShuLiang")%>’ 

/>
<asp:RegularExpressionValidator id="revS" runat="server" C ErrorMessage="must be integer" Validati />
</ItemTemplate>
</asp:TemplateColumn>
<asp:TemplateColumn HeaderText="单价"> 
<ItemTemplate>
<asp:TextBox id="DanJian" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_DanJian")%>’ 

/>
<asp:RegularExpressionValidator id="revS2" runat="server" C ErrorMessage="must be numeric" Validati />
</ItemTemplate>
</asp:TemplateColumn>
<asp:TemplateColumn HeaderText="金额"> 
<ItemTemplate>
<asp:TextBox id="JinE" runat=’server’ Text=’<%# DataBinder.Eval(Container.DataItem,"DG_JinE")%>’ />
</ItemTemplate>
</asp:TemplateColumn>
<script language="javascript">
function DoCal()
{
var e = event.srcElement;
var row = e.parentNode.parentNode;
var txts = row.all.tags("INPUT");
if (!txts.length || txts.length < 3)
return;
var q = txts[txts.length-3].value;
var p = txts[txts.length-2].value;
if (isNaN(q) || isNaN(p))
return;
q = parseInt(q);
p = parseFloat(p);
txts[txts.length-1].value = (q * p).toFixed(2);
}
</script>

3.datagrid选定比较底下的行时,为什么总是刷新一下,然后就滚动到了最上面,刚才选定的行因屏幕的关系就看不到了。

page_load 

page.smartNavigation=true

4.在Datagrid中修改数据,当点击编辑键时,数据出现在文本框中,怎么控制文本框的大小?

private void DataGrid1_ItemDataBound(obj sender,DataGridItemEventArgs e)
{
    for(int i=0;i<e.Item.Cells.Count-1;i++)
    if(e.Item.ItemType==ListItemType.EditType)
    {
        e.Item.Cells.Attributes.Add("Width", "80px")
    } 
}

5.对话框

private static string ScriptBegin = "<script language=\"JavaScript\">";
private static string ScriptEnd = "</script>";
public static void ConfirmMessageBox(string PageTarget,string Content)
{
    string C+Content+"');"+"if(retValue){window.location='"+PageTarget+"';}";
    ConfirmContent=ScriptBegin + ConfirmContent + ScriptEnd;
    Page ParameterPage = (Page)System.Web.HttpContext.Current.Handler;
    ParameterPage.RegisterStartupScript("confirm",ConfirmContent);
    //Response.Write(strScript);
}

6.将时间格式化:string aa=DateTime.Now.ToString("yyyy年MM月dd日");

取当前年月日时分秒:

currentTime=System.DateTime.Now;
取当前年:

int 年= DateTime.Now.Year;
取当前月:

int 月= DateTime.Now.Month;
取当前日:

int 日= DateTime.Now.Day;
取当前时:

int 时= DateTime.Now.Hour;
取当前分:

int 分= DateTime.Now.Minute;
取当前秒:

int 秒= DateTime.Now.Second;
取当前毫秒:

int 毫秒= DateTime.Now.Millisecond;

7.自定义分页代码:

先定义变量 :

public static int pageCount; //总页面数 
public static int curPageIndex=1; //当前页面 
//下一页: 
if(DataGrid1.CurrentPageIndex < (DataGrid1.PageCount - 1)) { 
    DataGrid1.CurrentPageIndex += 1; 
    curPageIndex+=1; 

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

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

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

//直接页面跳转: 
int a=int.Parse(JumpPage.Value.Trim());//JumpPage.Value.Trim()为跳转值 
if(a<DataGrid1.PageCount) { 
    this.DataGrid1.CurrentPageIndex=a; 

bind();[SPAN]

8.DataGrid使用:

添加删除确认:

private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) 

    foreach(DataGridItem di in this.DataGrid1.Items) { 
        if(di.ItemType==ListItemType.Item||di.ItemType==ListItemType.AlternatingItem) { 
            ((LinkButton)di.Cells[8].Controls[0]).Attributes.Add("onclick","return confirm('确认删除此项吗?');"); 
        } 
    } 
}

样式交替:

ListItemType itemType = e.Item.ItemType; 
if (itemType == ListItemType.Item ) { 
    e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor='#FFFFFF';"; 
    e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor='#d9ece1';cursor='hand';" ; 

else if( itemType == ListItemType.AlternatingItem) { 
    e.Item.Attributes["onmouseout"] = "javascript:this.style.backgroundColor='#a0d7c4';"; 
    e.Item.Attributes["onmouseover"] = "javascript:this.style.backgroundColor='#d9ece1';cursor='hand';" ; 
}

添加一个编号列:

DataTable dt= c.ExecuteRtnTableForAccess(sqltxt); //执行sql返回的DataTable 
DataColumn dc=dt.Columns.Add("number",System.Type.GetType("System.String")); 
for(int i=0;i<dt.Rows.Count;i++) {
    dt.Rows["number"]=(i+1).ToString(); 

DataGrid1.DataSource=dt; 
DataGrid1.DataBind(); 
//DataGrid1中添加一个CheckBox,页面中添加一个全选框 
private void CheckBox2_CheckedChanged(object sender, System.EventArgs e) {
    foreach(DataGridItem thisitem in DataGrid1.Items) { 
        ((CheckBox)thisitem.Cells[0].Controls[1]).Checked=CheckBox2.Checked; 
    } 
}

将当前页面中DataGrid1显示的数据全部删除

foreach(DataGridItem thisitem in DataGrid1.Items) {
    if(((CheckBox)thisitem.Cells[0].Controls[1]).Checked) { 
        string strloginid= DataGrid1.DataKeys[thisitem.ItemIndex].ToString(); 
        Del (strloginid); //删除函数 
    } 
}

9.当文件在不同目录下,需要获取数据库连接字符串(如果连接字符串放在Web.config,然后在Global.asax中初始化)

在Application_Start中添加以下代码:

Application["ConnStr"]=this.Context.Request.PhysicalApplicationPath+ConfigurationSettings.
AppSettings["ConnStr"].ToString();

10.变量.ToString()

字符型转换 转为字符串

12345.ToString("n"); //生成 12,345.00 
12345.ToString("C"); //生成 ¥12,345.00 
12345.ToString("e"); //生成 1.234500e+004 
12345.ToString("f4"); //生成 12345.0000 
12345.ToString("x"); //生成 3039 (16进制) 
12345.ToString("p"); //生成 1,234,500.00%
11.变量.Substring(参数1,参数2);

截取字串的一部分,参数1为左起始位数,参数2为截取几位。 如:

string s1 = str.Substring(0,2);

12.在自己的网站上登陆其他网站:(如果你的页面是通过嵌套方式的话,因为一个页面只能有一个FORM,这时可以导向另外一个页面再提交登陆信息)

<SCRIPT language="javascript"> 
<!-- 
function gook(pws) 

    frm.submit(); 

//--> 
</SCRIPT> <body leftMargin="0" topMargin="0"  marginwidth="0" marginheight="0"> 
<form name="frm" action=" http://www.xxx.com " method="post"> 
<tr> 
<td>
<input id="f_user" type="hidden" size="1" name="f_user" runat="server">
<input id="f_domain" type="hidden" size="1" name="f_domain" runat="server">
<input class="box" id="f_pass" type="hidden" size="1" name="pwshow" runat="server"> 
<INPUT id="lng" type="hidden" maxLength="20" size="1" value="5" name="lng">
<INPUT id="tem" type="hidden" size="1" value="2" name="tem"> 
</td> 
</tr> 
</form>

文本框的名称必须是你要登陆的网页上的名称,如果源码不行可以用vsniffer 看看。

下面是获取用户输入的登陆信息的代码:

string name; 
name=Request.QueryString["EmailName"]; 
try 

    int a=name.IndexOf("@",0,name.Length); 
    f_user.Value=name.Substring(0,a); 
    f_domain.Value=name.Substring(a+1,name.Length-(a+1)); 
    f_pass.Value=Request.QueryString["Psw"]; 

catch 

    Script.Alert("错误的邮箱!"); 
    Server.Transfer("index.aspx"); 
}

13.datagrid分页中如果删除时出现超出索引

public void jumppage(System.Web.UI.WebControls.DataGrid dg) { 
    int int_PageLess; //定义页面跳转的页数 
    //如果当前页是最后一页 
    if(dg.CurrentPageIndex == dg.PageCount-1) { 
        //如果就只有一页 
        if(dg.CurrentPageIndex == 0) { 
            //删除后页面停在当前页 
            dg.CurrentPageIndex = dg.PageCount-1; 
        } 
        else { 
            //如果最后一页只有一条记录 
            if((dg.Items.Count % dg.PageSize == 1) || dg.PageSize == 1) { 
                //把最后一页最后一条记录删除后,页面应跳转到前一页 
                int_PageLess = 2; 
            } 
            else //如果最后一页的记录数大于1,那么在最后一页删除记录后仍然停在当前页 { 
                int_PageLess = 1; 
            } 
            dg.CurrentPageIndex = dg.PageCount - int_PageLess; 
        } 
    } 
}

14.警告窗口

/// 服务器端弹出alert对话框 
///  
/// 提示信息,例子:"不能为空!" 
/// Page类 
public void Alert(string str_Message,Page page) { 
    page.RegisterStartupScript("",""); 
}

15.重载此警告窗口,使某控件获得焦点

/// 服务器端弹出alert对话框,并使控件获得焦点 
///  
/// 获得焦点控件Id值,比如:txt_Name 
/// 提示信息,例子:"请输入您姓名!" 
/// Page类 
public void Alert(string str_Ctl_Name,string str_Message,Page page) { 
    page.RegisterStartupScript("",""); 
}

16.确认对话框

/// 服务器端弹出confirm对话框 
///  
/// 提示信息,例子:"您是否确认删除!" 
/// 隐藏Botton按钮Id值,比如:btn_Flow 
/// Page类 
public void Confirm(string str_Message,string btn,Page page) { 
    page.RegisterStartupScript("",""); 
}


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:个人博客

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP