coolite中在UserControl中使用Coolite.AjaxMethods方法

Coolite Toolkit提供的Coolie.AjaxMethods.方法名直接调用后置方法。但当我们在UserControl中的前台代码中却无法使用此种方法。不过,Coolite Toolkit还提供了更强大的页面方法调用功能,就是他可以调用母版页(MasterPage)和用户自定义控件(UserControl)里的方法。 这里只说明调用UserControl方法。

调用方法:

  调用UserControl需要将UserControl类设置别名才能成功调用。如下边的UserControl后台代码,注意红色部分设置别名为"UserControlSapce"。

代码
using  Coolite.Ext.Web;

[AjaxMethodProxyID(IDMode = AjaxMethodProxyIDMode.Alias, Alias = "UserControlSapce")]
public   partial   class  UserControl_UseUserControlAjax_WebUserControlAjax : System.Web.UI.UserControl
{
    
protected   void  Page_Load( object  sender, EventArgs e)
    {
    }

    
///   <summary>
    
///  供前台调用的方法
    
///   </summary>  
    
///   <returns></returns>
    [AjaxMethod]
    
public   string  PageAjaxMethod()
    {
        
return  DateTime.Now.ToString();
    }
}

 

UserControl.ascs源码为: 注意红色部分是调用后台Ajax的方法。

代码
<% @ Control Language = " C# "  AutoEventWireup = " true "  CodeFile = " WebUserControlAjax.ascx.cs "
    Inherits = " UserControl_UseUserControlAjax_WebUserControlAjax "   %>
<% @ Register Assembly = " Coolite.Ext.Web "  Namespace = " Coolite.Ext.Web "  TagPrefix = " ext "   %>
< ext:Panel  ID ="Panel1"  runat ="server"  Height ="300"  Title ="用户自定义控件内容" >
    
< Body >
        
< ext:Button  ID ="btnUseAjax"  runat ="server"  Text ="调用Ajax" >
            
< Listeners >
                
<% -- 此处调用自定义控件后台的PageAjaxMethod方法,注意此处的命名空间为UserControlSapce -- %>
                
< Click  Handler =" Coolite.AjaxMethods.UserControlSapce.PageAjaxMethod(
                {
                    success:function(result)
                    {
                        Ext.Msg.alert(result);
                    }
                });"   />
            
</ Listeners >
        
</ ext:Button >
    
</ Body >
</ ext:Panel >

 

 父界面的源码为:父界面后台没有代码。

代码
<% @ Page Language = " C# "  AutoEventWireup = " true "  CodeFile = " frmUseControlAjax.aspx.cs "
    Inherits = " UserControl_UseUserControlAjax_frmUseControlAjax "   %>

<% @ Register Assembly = " Coolite.Ext.Web "  Namespace = " Coolite.Ext.Web "  TagPrefix = " ext "   %>
<% @ Register Src = " WebUserControlAjax.ascx "  TagName = " WebUserControlAjax "  TagPrefix = " uc1 "   %>
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html  xmlns ="http://www.w3.org/1999/xhtml" >
< head  runat ="server" >
    
< title ></ title >
</ head >
< body >
    
< ext:ScriptManager  ID ="ScriptManager1"  runat ="server" >
    
</ ext:ScriptManager >
    
< form  id ="form1"  runat ="server" >
    
< div >
        
< ext:Panel  ID ="Panel1"  runat ="server"  Height ="300"  Title ="Title" >
            
< Body >
                
< div >
                   
<% --  加载用户自定义控件,并执行用户控件中的自定义事件 -- %>
                    
< uc1:WebUserControlAjax  ID ="WebUserControlAjax1"  runat ="server"   />
                
</ div >
            
</ Body >
        
</ ext:Panel >
    
</ div >
    
</ form >
</ body >
</ html >

 

结果为:

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值