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

 

问:
1.如何在JavaScript访问C#函数?
2.如何在JavaScript访问C#变量?
3.如何在C#中访问JavaScript的已有变量?
4.如何在C#中访问JavaScript函数?
 
问题1答案如下:
javaScript函数中执行C#代码中的函数:
方法一:1、首先建立一个按钮,在后台将调用或处理的内容写入button_click中;
        2、在前台写一个js函数,内容为document.getElementById("btn1").click();
        3、在前台或后台调用js函数,激发click事件,等于访问后台c#函数;

方法二:1、函数声明为public             
           后台代码(把public改成protected也可以)
           public string ss()
           {
              return("a");
           }
        2、在html里用<%=fucntion()%>可以调用
           前台脚本
           <script language=javascript>
           var a = "<%=ss()%>";
           alert(a);
           </script>
方法三:1、<script language="javascript">
           <!--
           function __doPostBack(eventTarget, eventArgument)
           {
              var theForm = document.Form1;     //指runat=server的form
              theForm.__EVENTTARGET.value = eventTarget;
              theFrom.__EVENTARGUMENT.value = eventArgument;
              theForm.submit();
           }
           -->
           </script>
           <input id="Button1" type="button" name="Button1" value="按钮" οnclick="javascript:__doPostBack('Button1','')">
        
方法四:<script language="javascript">
function SubmitKeyClick()
{
    if (event.keyCode == 13)
    {
        event.cancelBubble = true;
        event.returnValue = false;
        document.all.FunName.value="你要调用的函数名";
        document.form[0].submit();
    }
}
</script>

<INPUT οnkeypress="SubmitKeyClick()" id="aaa" type="text">
<input type="hidden" name="FunName"> 〈!--用来存储你要调用的函数 --〉

在.CS里有:
public Page_OnLoad()
{
if (!Page.IsPost())
{
string strFunName=Request.Form["FunName"]!=null?Request.Form["FunName"]:"";
//根据传回来的值决定调用哪个函数
switch(strFunName)
{
case "enter()":
enter() ; //调用该函数
break;
case "其他":
//调用其他函数
break;
default:
//调用默认函数
break;
}
}
}

public void enter()
{
//……比如计算某值
}

问题2.如何在JavaScript访问C#变量?
答案如下:
方法一:1、通过页面上隐藏域访问<input id="xx" type="hidden" runat="server">
方法二:1、如后台定义了PUBLIC STRING N;前台js中引用该变量的格式为'<%=n%>'或"+<%=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函数?
答案如下:
c#代码中执行javaScript函数:
方法一:1、Page.RegisterStartupScript("ggg","<script>SetVisible(1);</script>");
方法二:使用Literal类,然后
private void Button2_Click(object sender, System.EventArgs e)
{
 string str;
 str="<script language='javascript'>";
 str+="selectRange()";
 str+="</script>";
 //Literal1.Visible=true;
 Literal1.Text=str;
}

-----------------------------------------------------

我有一个HTML的登陆页面,可以输入用户名和密码。然后有两个按钮,一个是登陆,一个是注册。登陆按钮将页面提交到一个JSP,在JSP中进行用户名称 验证。如果验证成功,就<jsp:forward>到论坛首页,如果验证失败,就<jsp:forward>到登陆页面重登陆。 我想实现的功能是,如果验证失败的话,能弹出一个对话框,alert("密码错误"),但是我不知道该怎么使用。我直接在JSP源文件里 写<javascript   alert("密码错误")>,不行  
  下面是源文件,老烦各位大虾米在给看看!小弟先谢谢了!  
  <%@   page   contentType="text/html;   charset=gb2312"   language="java"   import="java.sql.*"   errorPage="err_techForumIndex.jsp"   %>  
   
  <!DOCTYPE   HTML   PUBLIC   "-//W3C//DTD   HTML   4.01   Transitional//EN"   "http://www.w3.org/TR/html4/loose.dtd">  
   
  <html>  
   
  <head>  
   
  <meta   http-equiv="Content-Type"   content="text/html;   charset=gb2312">  
   
  <title>无标题文档</title>  
   
  </head>  
   
  <body>  
   
  <form   name="form1"   method="post"   action=""   onSubmit="notice()">  
   
  <%  
      //得到用户登陆信息:  
      String   current_userName   =   request.getParameter("userName");  
      String   current_password   =   request.getParameter("password");  
      //变量checkPassword用来存储从数据库里读出来的用户密码  
      String   checkPassword="";  
   
      //通过建立数据库连接来验证用户登陆:  
   
   
   
      //加载数据库驱动:  
      String   DBdriver="org.gjt.mm.mysql.Driver";  
  try   {  
  //建立数据库驱动  
  Class.forName(DBdriver).newInstance();  
  }catch(java.lang.ClassNotFoundException   e)   {  
    //没找到驱动异常  
  System.err.println(e.getMessage());  
  out.println(e.getMessage());  
  }  
   
      //建立连接:  
  try   {  
  String   url   =   "jdbc:mysql://localhost/poseidon?user=root&password=&useUnicode=true&characterEncoding=GBK";  
          Connection   conn=   DriverManager.getConnection(url);  
   
      //执行数据库查询语句并返回结果集  
      String   sql=   "SELECT   *   FROM   t_userinfo   WHERE   userName='"+current_userName+"'   ";  
      Statement   stmt   =   conn.createStatement();  
      ResultSet   rst   =   stmt.executeQuery(sql);  
   
      //通过查询用户在数据库的注册名得到用户的密码  
   
      while(rst.next())  
      {  
   
      checkPassword=rst.getString("password");  
   
      }  
   
   
   
      if(checkPassword.equals(current_password))  
      {  
      if(!conn.isClosed())  
      {  
      rst.close();  
      stmt.close();  
      conn.close();  
      }  
      %>  
   
   
  <jsp:forward   page="techForumIndex.jsp">  
   
  <jsp:param   name="userName"   value="<%=current_userName%>"/>  
   
  <jsp:param   name="password"   value="<%=current_password%>"/>  
   
  </jsp:forward>  
   
   
  <%  
   
  }  
  else  
  {  
  if(!conn.isClosed())  
      {  
      rst.close();  
      stmt.close();  
      conn.close();  
      }  
      %>  
                                                          我想在这里写一个意识密码错误的提示信息,利用alert()  
  <jsp:forward   page="techForumLogin.html">  
    <jsp:param   name="userName"   value="<%=current_userName%>"/>  
  </jsp:forward>  
   
  <%  
  }  
   
      }   catch(SQLException   ex)   {  
  System.err.println(ex.getMessage());  
  out.println(ex.getMessage());  
   
  out.println(checkPassword);  
    }  
  %>  
                          <input   type="hidden"   name="hiddenField">  
      <table   width="100%"     border="0"   cellspacing="0"   cellpadding="0">  
   
  <tr>  
   
  <td>&nbsp;</td>  
   
  </tr>  
   
      </table>  
   
  </form>  
   
  </body>  
   
  </html> 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值