Chinaunix首页 | 论坛 | 博客
  • 博客访问: 194040
  • 博文数量: 55
  • 博客积分: 2330
  • 博客等级: 大尉
  • 技术积分: 504
  • 用 户 组: 普通用户
  • 注册时间: 2010-07-20 22:55
文章分类

全部博文(55)

文章存档

2013年(6)

2012年(7)

2011年(7)

2010年(35)

我的朋友

分类: 系统运维

2011-06-03 11:15:43

C#代码与javaScript函数的相互调用:

1.如何在JavaScript访问C#函数?

2.如何在JavaScript访问C#变量?

3.如何在C#中访问JavaScript的已有变量?

4.如何在C#中访问JavaScript函数?

问题1答案如下:

javaScript函数中执行C#代码中的函数:

方法一:页面和页面类相结合

1、函数声明为public             

             后台代码(把public改成protected也可以)

             public string ss()

             {

                return("a");

             }

          2、在html里用<%=ss()%>可以调用//是C#中后台的函数名称

             前台脚本

            

方法二: JavaScript异步调用定义在ASP.Net页面中的方法   
            1.将该方法声明为公有(public);   
            2.将该方法声明为类方法(C#中的static,VB.NET中的Shared),而不是实例方法;   
            3.将该方法添加【WebMethod】属性   
            4.将页面中ScriptManager控件的EnablePageMethods属性设置为true;   
            5.在客户端使用如下JavaScript语法调用该页面方法   
                PageMethods.[MethodName](param1,param2,...,callbackFunction);   
            6.为客户端异步调用指定回调函数,在回调函数中接受返回值并进一步处理;   
            7.添加 using System.Web.Services;  

示例:

前台JavaScript代码



    无标题页

   



   

//ScriptManager控件管理脚本的,

注意设置EnablePageMethods="true"此属性
   
   


       
   

   



 后台代码(.cs文件)
using System;
using System.Configuration;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Web.Services;//添加web服务引用

public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
      

    }
    [WebMethod]//标示为web服务方法属性
    public static  string sayhell(string say)//注意函数的修饰符,只能是静态的
    {
        return say;
    }
}

方法三: JavaScript异步调用定义在Web服务类中的方法

1.添加一个web服务标示该服务为 允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务

 对应属性为[System.Web.Script.Services.ScriptService]

2.将该方法声明public并将该方法标示为[webMethod]属性方法  
3.在页面中ScriptManager控件并添加web服务引用    
4.在客户端使用如下JavaScript语法调用web服务方法

 WebService.HelloWorld("helloWord",function(res)//Webservice是web服务页面名称 HelloWord为web服务页面类中的方法,function为回调JavaScript函数主要是处理返回的结果
     {
     alert(res);
     });   

示例:

页面代码



    无标题页

   


   


   
   //注意要引用web服务
   

   

       
       
   

   


web服务后台代码

using System;
using System.Collections;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;

///


///WebService 的摘要说明
///

[WebService(Namespace = "")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
//若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。 
 [System.Web.Script.Services.ScriptService]//注意要添加该标示
public class WebService : System.Web.Services.WebService {

    public WebService () {

        //如果使用设计的组件,请取消注释以下行 
        //InitializeComponent(); 
    }

[WebMethod]//方法要标示的属性
    public string HelloWorld(string result) {
        return result;
    }
    
}

问题2答案如下: 如何在JavaScript访问C#变量

方法一:1、通过页面上隐藏域访问

方法二:1、如后台定义了PUBLIC STRING N;前台js中引用该变量的格式为'<%=n%>'或"+<%=n%>+"

方法三:1、或者你可以在服务器端变量赋值后在页面注册一段脚本

             ""

             tmp是后台变量,然后js中可以直接访问temp获得值。

问题3 .如何在C#中访问JavaScript的已有变量?

方法一:1、前台使用服务器文本控件隐藏域,将js变量值写入其中;后台直接通过控件id访问和调用

方法二:可以用cookie或session存储变量值,后台直接使用

问题4 C#代码执行JavaScript函数和调用JavaScript函数

方法一: .尽量少用Response.Write(< script>< /script>);这种方法,它会影响CSS导致页面效果偏差

方法二:C#中使用ScriptManager.RegisterStartupScript(this, this.GetType(), "edit", "CSharpCallJs('"+param1+"','"+param2+"')",

示例:

脚本函数

function CSharpCallJs(param1,param2)   
        {   
            alert(param1 + param2);   
        } 

页面后台代码

ScriptManager.RegisterStartupScript(this, this.GetType(), "edit", "CSharpCallJs('" + param1 + "','" + param2 + "');", true);// 关键代码调用页面脚本函数的代码

方法三:C#中使用 Page.RegisterStartupScript("ggg","");

方法四:C#中使用Literal类(类似label类)

示例代码

private void Button2_Click(object sender, System.EventArgs e)

{

string str;

str="";

//Literal1.Visible=true;

Literal1.Text=str;

以上是自己工作中的总结,主要是总结了JavaScript和后台的交互以及asp.net中前台和后台的交互



原文链接: http://www.cnblogs.com/poleices/archive/2011/02/24/1963727.html

阅读(3942) | 评论(0) | 转发(0) |
0

上一篇:web页面布局图示

下一篇:存储之一

给主人留下些什么吧!~~