• (转)ASP.NET调用javascript脚本的方法总结


    http://www.cnblogs.com/zmcblogs/archive/2009/12/24/1631335.html 

    1、直接在前台调用 javascript 函数

     

    很简单,在 head 元素之间加入 script 元素,将 type 元素设置为 " text/javascript "

    如:

    <head runat="server">
    <script type="text/javascript" >
    function ShowName(str)
    {
    alert("您的名字为:("+str+")");
    }
    </script>
        <title>using javascript</title>
    </head>


    之后在body 元素间,通过事件来访问 如 要通过button1 的单击事件(onclientclick)来访问 javascript 函数

    示例如下:

    <asp:Button ID="Button1" runat="server" Text="Button"  onclientclick="ShowName('XXX')"  />

    这时运行项目,单击 button时,会显示"您的名称为XXX"

    这就是一个简单的javascript 函数.

     

    2、在前台通过 js文件 调用

     

    方法与 (1)一样 只不过需要指定 .js 文件

    示例如下:

    <head runat="server">
    <script type="text/javascript" src="JScript.js">
    </script>
        <title>using javascript</title>
    </head>

    之后在body 元素间,通过事件来访问 如 要通过button1 的单击事件(onclientclick)来访问 javascript 函数

    示例如下:

    //此时 .js文件中必须有 ShowName 方法

    <asp:Button ID="Button1" runat="server" Text="Button"  onclientclick="ShowName('XXX')"  />

     

    3、在后台调用 javascript 函数,函数在.js文件中

     

    前台的head 元素

    <head runat="server">
    <script type="text/javascript" src="JScript.js">
    </script>
        <title>using javascript</title>
    </head>

    后台的需要添加如下代码

    Button1.Attributes.Add("onclick", "showname1(XXX)");

     

    4、在后台调用 javascript 函数,函数写在 .js文件中,但并没有在前台定义

     

    //获得.js文件

    string myscript = "JScript.js";

    //注册.js文件, 如果此时查看源码,会得到如下代码

    //<script> src ="JScript.js" type="text/javascript"><script>

    Page.ClientScript.RegisterClientScriptInclude("myKey", myscript);

    //同上
    Button1.Attributes.Add("onclick", "showname1(123)");

     

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

     

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

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

     

    6.用ClientScript类动态添加脚本

     

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

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

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

    注意,以上所有方法中,后台代码都不能有转化当前页的代码,比如Redirect等,要把转页代码放在脚本里面

    扫描上面二维码关注我
    如果你真心觉得文章写得不错,而且对你有所帮助,那就不妨帮忙“推荐"一下,您的“推荐”和”打赏“将是我最大的写作动力!
    本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接.
  • 相关阅读:
    [SDOI2015]约数个数和
    [POI2007]ZAP-Queries
    fpu栈溢出
    shader 汇编
    sample a texture as a rendertarget
    ID3d11asynchronous
    DEVICE DRAW VERTEX BUFFER TOO SMALL
    模型的一个点显示在原点
    setrendertraget 上下颠倒
    skinned mesh 蜘蛛样
  • 原文地址:https://www.cnblogs.com/kerrycode/p/1738005.html
Copyright © 2020-2023  润新知