zoukankan      html  css  js  c++  java
  • 前台ji调用后台的方法和后台调用前台js的方法

    一、C#后台调用前台javascript的五种方法

    1,OnClientClick    (vs2003不支持这个方法)
    <asp:Button ID="Button1" runat="server" Text="Button" OnClientClick="client_click()" OnClick="Button1_Click" />
    client_click() 就是javascript的一个方法。

    2,Button1.Attributes.Add("onclick", "return Client_Click()");
    “Client_Click() “是一个前台方法,可以替换成一般的脚本如:retrun confirm('确定删除吗?')

    3,是我自认为最灵活的一种,ClientScript.RegisterStartupScript
    例子:StringBuilder sb = new StringBuilder();
            sb.Append("<script language='javascript'>");
            sb.Append("Button2_onclick('" + serverPath + "')");
            sb.Append("</script>");
            ClientScript.RegisterStartupScript(this.GetType(), "LoadPicScript", sb.ToString());

    4. 用Response.Write方法写入脚本

    比如在你单击按钮后,先操作数据库,完了后显示已经完成,可以在最后想调用的地方写上
    Response.Write("<script type='text/javascript'>alert();</script>");

    这个方法有个缺陷就是不能调用脚本文件中的自定义的函数,只能调用内部函数,具体调用自定义的函数只能在Response.Write写上函数定义,比如Response.Write("<script type='text/javascript'>function myfun(){...}</script>");

    5 用ClientScript类动态添加脚本

        用法如下:在想调用某个javascript脚本函数的地方添加代码,注意要保证MyFun已经在脚本文件中定义过了。

        ClientScript.RegisterStartupScript(ClientScript.GetType(), "myscript", "<script>MyFun();</script>");

    这个方法比Response.Write更方便一些,可以直接调用脚本文件中的自定义函数。

     

    二、javascript函数中执行C#代码中的函数:
    方法一:

     1、首先建立一个按钮,在后台将调用或处理的内容写入button_click中;
    2、在前台写一个js函数,内容为document.getElementById("btn1").click();
    3、在前台或后台调用js函数,激发click事件,等于访问后台c#函数;

    方法二:

     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="按钮" onclick="javascript:__doPostBack('Button1','')">

     方法三 直接用__doPostBack方法执行服务器端控件的后台方法

    function CtrlSave()
    {
        if (event.ctrlKey && event.keyCode==83)
            __doPostBack('btnSave','');
    }

    或者

    eval(__doPostBack('btnSave','')) 这样就只会执行服务其端控件的后台方法,不会之前前台的onclientclick方法 直接跳过

    但是使用document.getElementById("btnSave").click();则会执行控件的js方法

  • 相关阅读:
    springboot应用docker部署调用phantomjs出现permission denied修复方法
    vue某单元格设置背景色
    vue编辑当行数据,弹窗赋值
    vue使用element-ui的el-input监听不了键盘事件解决
    js获取当前域名
    Jedis Redis 模糊匹配 取得 key 列表
    电脑启机时出windowssystem32driversootsafe64.sys
    Vue子组件调用父组件的方法
    Docker 连接mongodb
    Unsatisfied dependency expressed through field 'mongoTemplate'
  • 原文地址:https://www.cnblogs.com/linzheng/p/1824169.html
Copyright © 2011-2022 走看看