zoukankan      html  css  js  c++  java
  • JS调用服务器端方法

    利用Anthem.net 实现前台javascript调用服务器端c#函数 及流程分析

    Javascript调用服务器端c#函数(页面函数, 母版函数, 控件函数), 这个功能很早anthem.net就提供了, 且在帮助手册中有相关的例子, 但自己没怎么注意, 今天看同事研究anthem.net时, 突然发现了 . 看来anthem.net给我们留下的发挥空间还是挺大的.
    下面举一个简单的例子, 及分析下执行流程.

    例子如下:

    1. CS定义函数Add

    public int Add(int a, int b) { return a + b; }

    2. 添加函数的属性, 这样才能在客户端调用他.

        [Anthem.Method]
        public int Add(int a, int b)
        {
           return a + b;
        }

    3. 在页面加载时注册Anthem.Manager

    void Page_Load() { Anthem.Manager.Register(this); }

    4. 在aspx页面添加以下html控件

    <input id="a" size="3" value="1" />
    <input id="b" size="3" value="2" />
    <button onclick="DoAdd(); return false;" type="button">Add</button>
    <input id="c" size="6">

    5. 添加javascript函数, 用来调用服务器端方法.

    <script type="text/javascript">
    function DoAdd() {
        Anthem_InvokePageMethod(
        'Add',
        [document.getElementById('a').value, document.getElementById('b').value],
        function(result) { document.getElementById('c').value = result.value; }
        );
    }
    </script>

    6. 第一个参数"add"是服务器端函数名称

    Anthem_InvokePageMethod(
    'Add',
    [document.getElementById('a').value, document.getElementById('b').value],
    function(result) { document.getElementById('c').value = result.value; }
    );

    7. 第二个参数时传给服务器端函数的参数

    Anthem_InvokePageMethod(
    'Add',
    [document.getElementById('a').value, document.getElementById('b').value],
    function(result) { document.getElementById('c').value = result.value; }
    );

    8. 第三个参数是服务器端函数执行后的回调方法.

    Anthem_InvokePageMethod(
    'Add',
    [document.getElementById('a').value, document.getElementById('b').value,
    function(result) { document.getElementById('c').value = result.value; }
    );

    9. 回调结果result是一个对象, 具有一个value属性和error属性. 如果服务器端函数调用出现错误, 则记录在error中, value是返回服务器端方法的执行结果.

    Anthem_InvokePageMethod(
    'Add',
    [document.getElementById('a').value, document.getElementById('b').value,
    function(result) { document.getElementById('c').value = result.value; }
    );

    转自:http://anthem.talloaksoftware.com/InvokePageMethod.aspx

    稍微分析以下执行流程:

    前台执行DoAdd()执行 Anthem_InvokePageMethod,  这个函数执行一个anthem callback, 模拟对当前页面进行请求, 具体的流程参见我以前写的一篇分析文章:简略的分析一下Anthem无刷新控件的实现原理和流程

    主要用到的相关方法在Manager.cs中
    下面的函数用来判断"Add"方法是否具有[Anthem.Method]属性

    private static MethodInfo FindTargetMethod(object target, string methodName)
    {
        Type type = target.GetType();
        MethodInfo methodInfo = type.GetMethod(methodName, BindingFlags.Instance | BindingFlags.Public | BindingFlags.NonPublic);
        if (methodInfo != null)
        {
            object[] methodAttributes = methodInfo.GetCustomAttributes(typeof(Anthem.MethodAttribute), true);
            if (methodAttributes.Length > 0)
            {
                return methodInfo;
            }
        }
        return null;
    }


    如果"add"具有具有[Anthem.Method]属性, 就通过反射调用该方法.
        

    if (methodName != null && methodName.Length > 0)
    {
        MethodInfo methodInfo = FindTargetMethod(targetObject, methodName);
        if (methodInfo == null)
        {
            error = "METHODNOTFOUND";
        }
        else
        {
            try
            {
                object[] parameters = ConvertParameters(methodInfo, req);
                val = InvokeMethod(targetObject, methodInfo, parameters);
            }
            catch (MethodAccessException ex)
            {
                if (!methodInfo.IsPublic)
                    error = string.Format("Anthem.Manager does not have permission to invoke method \"{0}\" in the current trust level. Please try making the method Public.", methodName);
                else
                    error = ex.Message;
            }
            catch (Exception ex)
            {
                error = ex.Message;
            }
        }
    }

  • 相关阅读:
    swift4.2
    swift4.2 打印devicetoken
    swift4.2
    (二十三)Dbutils 工具介绍
    (二十二)自定义简化版JDBC(Dbutils框架的设计思想)
    (二十一)配置三种开源数据库连接池
    (二十)自定义数据库连接池
    (十九)事务
    (十八)JDBC获取存储过程和主键
    (十七)使用JDBC进行批处理
  • 原文地址:https://www.cnblogs.com/88223100/p/1276598.html
Copyright © 2011-2022 走看看