原文地址:http://blog.csdn.net/wonsoft/article/details/2595743

C#与Javascript变量、函数之间的相互调用 

一、javascript调用C#代码解决方案

// 第一种情况:

1.后台方法:

  1. protected string CsharpVoid(string strCC)
  2. {
  3. return strCC;
  4. }

2.javascript 调用

  1. <script language="javascript">
  2. <!--
  3. var s = "<%=CsharpVoid("www. baidu.com")%>";
  4. document.write(s);
  5. // -->
  6. </script>

// 第二种情况:

1.后代码:

  1. protected void CsharpVoid()
  2. {
  3. string strCC = "www.baidu.com";
  4. Response.Write(strCC);
  5. }

2.调用方法:CsharpVoid()

  1. <script language="javascript">
  2. <!--
  3. document.write("<%CsharpVoid();%>");
  4. // -->
  5. </script>

可在页面中放一个按钮,把它设置为不可见style="display:none",然后,用脚本让此按钮点击

  1. document.all("button1").click();

在此按钮的C#后台中写事件代码,这就是最简单的脚本调用C#方法.

二、C#与Javascript变量、函数之间的相互调用

问题1:在JavaScript访问C#函数

方法一

1、首先建立一个按钮,在后台将调用或处理的内容写入button_click中;

2、在前台写一个js函数,内容为

  1. document.getElementById("btn1").click();

3、在前台或后台调用js函数,激发click事件,等于访问后台c#函数;

方法二

1、后台代码函数声明为public(protected也可以)

  1. public string ss()
  2. {
  3. return("a");
  4. }

2、前台:在html脚本里用<%=fucntion()%>可以调用

  1. <script language=javascript>
  2. <!--
  3. var a = "<%=ss()%>";
  4. alert(a);
  5. // -->
  6. </script>

方法三

  1. <script language="javascript">
  2. <!--
  3. function __doPostBack(eventTarget, eventArgument)
  4. {
  5. var theForm = document.Form1;       //指runat=server的form
  6. theForm.__EVENTTARGET.value = eventTarget;
  7. theFrom.__EVENTARGUMENT.value = eventArgument;
  8. theForm.submit();
  9. }
  10. // -->
  11. </script>
  12. <input id="Button1" type="button" name="Button1" value="按钮"   onclick="javascript:__doPostBack('Button1','')"/>

ASPX页面有包含asp:LinkButton或者带有AutoPostBack属性且其值为true的服务器控件时,ASP.NET会自动为页面生成下面的脚本:

  1. <input type="hidden" name="__EVENTTARGET" id="__EVENTTARGET" value="" />
  2. <input type="hidden" name="__EVENTARGUMENT" id="__EVENTARGUMENT" value="" />

这两个参数分别由隐藏的两个表单域__ EVENTTARGET和__ EVENTARGUMENT保存。 

这两个隐藏的表单可以查找引起页面回送的控件ID和回送时的参数:

  1. string target = Request.Params["__EVENTTARGET"];
  2. string args = Request.Params["__EVENTARGUMENT"];

asp:Button和asp:ImageButton不是使用__doPostBack回送页面,所以使用这两个控件回送页面时,上面的代码是无效的。

方法四:1、前台:

  1. <script language="javascript"><!--
  2. function SubmitKeyClick()
  3. {
  4. if (event.keyCode == 13)
  5. {
  6. event.cancelBubble = true;
  7. event.returnValue = false;
  8. document.all.FunName.value="你要调用的函数名";
  9. document.form[0].submit();
  10. }
  11. }
  12. // -->
  13. </script>
  14. <INPUT onkeypress="SubmitKeyClick()" id="aaa" type="text">
  15. <input type="hidden" name="FunName"><!--用来存储你要调用的函数 -->

2、后台CS代码:

  1. public Page_OnLoad()
  2. {
  3. if (!Page.IsPost())
  4. {
  5. string strFunName=Request.Form["FunName"]!=null?Request.Form["FunName"]:"";
  6. //根据传回来的值决定调用哪个函数
  7. switch(strFunName)
  8. {
  9. case "enter()":
  10. enter() ; //调用该函数
  11. break;
  12. case "其他":
  13. //调用其他函数
  14. break;
  15. default:
  16. //调用默认函数
  17. break;
  18. }
  19. }
  20. }
  21. public void enter()
  22. {
  23. //……比如计算某值
  24. }

问题2:在JavaScript访问C#变量

方法一:

1、通过页面上隐藏域访问

  1. <input id="xx" type="hidden" runat="server">

方法二

1、如后台定义了:

  1. public string n;

2、前台js中引用该变量的格式为

  1. '<%=n%>'
  2. //或
  3. "+<%=n%>+"
  4. //例:
  5. var ss="<%=n%>"

方法三:在服务器端变量赋值后在页面注册一段脚本

  1. "<script language='javascript'>var temp=" + tmp + "</script>"

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

问题3:在C#中访问JavaScript的已有变量

方法一:

1、前台使用静态文本控件隐藏域,将js变量值写入其中;

2、后台用request["id"]来获取值;

方法二:

可以用cookie或session问题4:在C#中访问JavaScript函数

方法一:

  1. Page.RegisterStartupScript("ggg","<script>SetVisible(1);
  2. </script>");

方法二:

1、前台使用Literal类:

  1. <asp:Literal ID="Literal1" runat="server"></asp:Literal>

2、后台CS代码:

  1. private void Button2_Click(object sender, System.EventArgs e)
  2. {
  3. string str;
  4. str="<mce:script language='javascript'><!--
  5. ";
  6. str+="selectRange()";
  7. str+="
  8. // --></mce:script>";
  9. //Literal1.Visible=true;
  10. Literal1.Text=str;
  11. }

C#与Javascript变量、函数之间的相互调用的更多相关文章

  1. JavaScript父子页面之间的相互调用

    父页面: <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head>< ...

  2. JAVA和C/C++之间的相互调用。

    在一些Android应用的开发中,需要通过JNI和 Android NDK工具实现JAVA和C/C++之间的相互调用. Java Native Interface (JNI)标准是java平台的一部分 ...

  3. C 程序与 C++ 程序之间的相互调用

    因为 C 编译器编译函数时不带参数的类型信息,只包含函数的符号名字.如 void foo( int x ) , C 编译器会将此函数编译成类似 _foo 的符号,C 链接器只要找到了调用函数的符号,就 ...

  4. Iframe父页面与子页面之间的相互调用

    iframe元素就是文档中的文档. window对象: 浏览器会在其打开一个HTML文档时创建一个对应的window对象.但是,如果一个文档定义了一个或者多个框架(即:包含一个或者多个frame或者i ...

  5. uLua学习笔记(三):Unity3D和Lua之间的相互调用

    这篇笔记主要集中学习一下uLua和Unity3D之间相互调用的方法,我们导入了uLua之后,现在会弹出一个类似学习屏幕的东西,如下: 先赞一个! Unity3D调用Lua Unity3D调用Lua的方 ...

  6. 关于cocos2d-x 和安卓之间的相互调用

    近期在研究cocos2d游戏移植安卓须要调用非常多方法.所以在研究之中写下它们之间相互调用 首先,cocos2d调用安卓 在一个.h文件里加入头文件 #include <jni.h> #i ...

  7. Javascript中函数的四种调用方式

    一.Javascript中函数的几个基本知识点: 1.函数的名字只是一个指向函数的指针,所以即使在不同的执行环境,即不同对象调用这个函数,这个函数指向的仍然是同一个函数. 2.函数中有两个特殊的内部属 ...

  8. javascript中函数的闭包自调用

    话不多说, 直接上代码 // 定义一个变量outerParam, 然后使用一个闭包函数给该变量初始化var outerParam = (function testClosure(param) { // ...

  9. C和Lua之间的相互调用

    前面的话 第一次接触Lua是因为Unity游戏中需要热更,但是一直没搞懂Lua是怎么嵌入到别的语言中执行的,如何互相调用的.这次打算好好了解一下C跟lua是如何交互的 那么如何使用Lua语言? lua ...

随机推荐

  1. vue中的$on,$emit,$once,$off源码实现

    这几种模式是基于订阅观察者模式的,维护一个事件中心,on的时候将事件按名称存在事件中心里,称之为订阅者,然后emit将对应的事件进行发布,去执行事件中心里的对应的监听器. 第一步就是创建一个构造构造, ...

  2. POJ2406 Power Strings(KMP)

    Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 56162   Accepted: 23370 Description Giv ...

  3. MySQL的Root用户密码

    缘由:最近北京市二环内大兴土木,各种挖沟埋线.忽而一纸通令周末断电,故多年不断电的服务器,便令人有了关机后是否还能正常启动的隐忧.其中一台较年迈的服务器中搭载有MySQL数据库.数据库内容本属于外包项 ...

  4. JavaScript--获取页面盒子中鼠标相对于盒子上、左边框的坐标

    分析: 外层边框是浏览器边框,内部盒子是页面的一个盒子,绿点是盒子中鼠标的位置.鼠标相对盒子边框的坐标=页面中(注意不是浏览器)鼠标坐标-盒子相对于浏览器边框的偏移量 第一步:求浏览器边框位置 x=e ...

  5. Mysql读写分离,主从同步实现

    随着用户量的增多,数据库操作往往会成为一个系统的瓶颈所在,因此我们可以通过实现数据库的读写分离来提高系统的性能. 通过设置主从数据库实现读写分离,主库负责“写”操作,从库负责“读”操作,根据压力情况, ...

  6. docker API 配置与使用

    在网上看到一大堆乱乱七八招的博客,很多都不能用,我根据这些天踩的坑来总结一下吧 首先!怎么配置 docker API 两种方法 在/etc/sysconfig/docker文件里加一行OPTIONS= ...

  7. U盘被分区后恢复方法

    一:运行cmd 二:输入diskpart,按enter. 三:输入list disk,按enter. 四:选择优U盘,输入select disk X(X代表磁盘后面的数字0.1,可磁盘的大小来判断数字 ...

  8. wamp环境下安装imagick扩展

    先上图,如下是安装成功后的phpinfo()界面: 安装步骤: 1.先确定安装版本,比如我的的php : php7.0.12  x86 ts 那么就需要三方版本 要一致:imagick软件本身( 如x ...

  9. Hadoop(2)--hdfs

    Hadoop(2) Hadoop底层封装的的是HDFS和MapReduce两种框架 在Hdfs中采用的是主从结构(Madter-slaver)就像领导和员工一样,领导负责整个公司的管理工作,而员工就负 ...

  10. ruby编码说明

    程序编码一般分几种情况: 1.源码文件编码 2.接收外部内容的编码 3.运行环境编码 4.操作系统编码 首先源码文件的编码,可以通过在ruby文件的头部添加一行申明即可,这样所有在源码里面出现的字符都 ...