Ajax 实现无刷新编辑页面

1.下载ajax, .net1.1版本ajaxpro.dll .net2.0就用ajaxpro2.dll
 
2.在VS项目里面添加它们的引用,并在Web.COnfig中配置(我这里用的是.net 2.0)
< system .web >
    
< httpHandlers >
      
< add  verb ="POST,GET"  path ="AjaxPro/*.ashx"  type ="AjaxPro.AjaxHandlerFactory, AjaxPro.2"   />
    
</ httpHandlers >
    ..
</ system.web >
 
3.建立一个aspx页面,HTML代码如下
<% @ Page Language = " C# "  AutoEventWireup = " true "  CodeFile = " test.aspx.cs "  Inherits = " test "   %>
< html   >
< head  runat ="server" >
    
< title >  Ajax  </ title >
</ head >
< body >
    
< form  id ="form1"  runat ="server" >
    
< div >
         
< asp:Label  ID ="Label1"  runat ="server"  Text ="标题:" ></ asp:Label >
        
< asp:TextBox  ID ="TextBox1"  runat ="server" ></ asp:TextBox >< br  />
        
< asp:TextBox  ID ="TextBox2"  runat ="server" ></ asp:TextBox >< br  />
        
< script  type ="text/javascript" >
           
<!--
            
function  insertDB()
            {
                
var  T1 = document.getElementById( " TextBox1 " );
                
var  T2 = document.getElementById( " TextBox2 " );
                log_test.InsertToDB(T1.value,T2.value,Result); 
// 调后台Ajax方法(test为类名),第三个参数是取返回值
            }
            
function  Result(GET)   // 取后台ajax方法的返回值
            {
                
if (GET.value == " ok " )
                {
                   alert('提交成功
! ');
                }
                
else
                {
                    alert('提交失败!');
                }
            }
            
-->
        
</ script >
        
< input  id ="Button3"  type ="button"  value ="提交"  onclick ="insertDB();"   />
        
</ div >
    
</ form >
</ body >
</ html >

aspx.cs代码如下

public  partial  class  test : System.Web.UI.Page
{
    
protected   void  Page_Load( object  sender, EventArgs e)
    {
        AjaxPro.Utility.RegisterTypeForAjax(
typeof (test));  // 注册类名
    }

    [AjaxPro.AjaxMethod]  
// ajax方法声明
     public   string  InsertToDB( string  T1, string  T2)
    {
        
string  insertStr  =   " Insert INTO Notify(N_Title,N_Content) Values (@N_Title,@N_Content) " ;
        SqlParameter[] pars 
= {
          
new  SqlParameter( " @N_Title " ,SqlDbType.NVarChar, 50 ),
          
new  SqlParameter( " @N_Content " ,SqlDbType.NVarChar),
        };
        pars[
0 ].Value  =  T1;
        pars[
1 ].Value  =  T2;
        
try
        {
     
// DB是项目里处理sql的类
            DB.ExecuteNonQuery(DB.ConnectionString, CommandType.Text, insertStr, pars);
            
return   " ok " ;
        }
        
catch  (Exception err)
        {
            
// WriteLog 是项目里写日志的类
            WriteLog wl  =   new  WriteLog(err.Message,err.StackTrace,err.Source);
            
return   " fail " ;
        }
    }
  
}

也可根据次方法修改成其他应用

转载于:https://www.cnblogs.com/anson2020/archive/2007/07/22/827512.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值