2

我们使用 asp.net UpdatePanel 和 ScriptManager/ScriptManagerProxy 来实现 ajax 相关功能;减少整页刷新和分别调用 WCF 服务。我们还在 UI 的某些部分使用 jQuery 和插件。

我们遇到了一些与 javascript 库相关的冲突问题,但遇到一些帖子表明使用 UpdatePanel 会产生更多开销。

我发现了一些对 UFrame 的有限参考:

http://www.codeproject.com/KB/aspnet/uframe.aspx

www.codeplex.com/uframe

这是 asp.net UpdatePanel 在商业上可行的替代品吗?

我们使用 ScriptManagerProxy 来引用 WCF 服务,并轻松创建和使用代理来调用各种 WCF 服务方法。

在这里使用 jQuery ajax 会是更有效的解决方案吗?我们已经在各种浏览器上运行良好,但现在似乎遇到了一些与安全相关的问题(如 FF Firebug:访问受限 URI 被拒绝”代码:“1012”中所见),这似乎是因为更多地使用 jQuery 而开始的。

根本不使用 ASP.NET Ajax 是否可能/可行?

4

2 回答 2

3

我一直只使用 Ajax,直到我厌倦了更新面板的低效率。它们可以工作,但是当您尝试在网站上做任何真实的事情时,速度太慢了。我的页面有几个更新面板,它们只需几秒钟即可刷新。

因此,我使用 Web 服务进行数据访问,转而使用 jQuery。这是一个伟大的举动。现在页面加载速度更快。由于我试图完全摆脱脚本管理器,因此有点失去了便利性,但是下面的一些 javascript 使调用服务变得更加容易。再加上一些宁静的 wcf 服务,它就像一个魅力。我已将整个页面转换为仅使用 javascript 和 restful 服务的编辑系统之类的窗口。

无论如何,这里有一些代码可以帮助在 jQuery 中调用服务

// *** Service Calling Proxy Class
function serviceProxy(serviceUrl) {
    var _I = this;
    this.serviceUrl = serviceUrl;

    // *** Call a wrapped object
    this.invoke = function(method, data, callback, error, bare) {
        // *** Convert input data into JSON - REQUIRES Json2.js
        var json = JSON2.stringify(data);

        // *** The service endpoint URL        
        var url = _I.serviceUrl + method;

        $.ajax({
            url: url,
            data: json,
            type: "POST",
            processData: false,
            contentType: "application/json",
            timeout: 10000,
            dataType: "text",  // not "json" we'll parse
            success:
                    function(res) {
                        if (!callback) return;

                        // *** Use json library so we can fix up MS AJAX dates
                        var result = JSON2.parse(res);

                        // *** Bare message IS result
                        if (bare)
                        { callback(result); return; }

                        // *** Wrapped message contains top level object node
                        // *** strip it off
                        for (var property in result) {
                            callback(result[property]);
                            break;
                        }
                    },
            error: function(xhr) {
                if (!error) return;
                if (xhr.responseText) {
                    var err = null;
                    try{ var err = JSON2.parse(xhr.responseText); }
                    catch(e) { err = xhr.responseText;}

                    if (err)
                        error(err);
                    else
                        error({ Message: "Unknown server error." })
                }
                return;
            }
        });
    }
}
if (!this.JSON2) {
    JSON2 = function() {
        function f(n) { return n < 10 ? '0' + n : n; }
        var escapeable = /["\\\x00-\x1f\x7f-\x9f]/g, gap, indent, meta = { '\b': '\\b', '\t': '\\t', '\n': '\\n', '\f': '\\f', '\r': '\\r', '"': '\\"', '\\': '\\\\' }, rep; function quote(string) {
            return escapeable.test(string) ? '"' + string.replace(escapeable, function(a) {
                var c = meta[a]; if (typeof c === 'string') { return c; }
                c = a.charCodeAt(); return '\\u00' + Math.floor(c / 16).toString(16) +
(c % 16).toString(16);
            }) + '"' : '"' + string + '"';
        }
        function str(key, holder) {
            var i, k, v, length, mind = gap, partial, value = holder[key]; if (value && typeof value === 'object' && typeof value.toJSON === 'function') { value = value.toJSON(key); }
            if (typeof rep === 'function') { value = rep.call(holder, key, value); }
            switch (typeof value) {
                case 'string': return quote(value); case 'number': return isFinite(value) ? String(value) : 'null'; case 'boolean': case 'null': return String(value); case 'object': if (!value) { return 'null'; }
                    if (value.toUTCString)
                    { var xx = '"\\/Date(' + value.getTime() + ')\\/"'; return xx; }
                    gap += indent; partial = []; if (typeof value.length === 'number' && !(value.propertyIsEnumerable('length'))) {
                        length = value.length; for (i = 0; i < length; i += 1) { partial[i] = str(i, value) || 'null'; }
                        v = partial.length === 0 ? '[]' : gap ? '[\n' + gap + partial.join(',\n' + gap) + '\n' + mind + ']' : '[' + partial.join(',') + ']'; gap = mind; return v;
                    }
                    if (typeof rep === 'object') { length = rep.length; for (i = 0; i < length; i += 1) { k = rep[i]; if (typeof k === 'string') { v = str(k, value, rep); if (v) { partial.push(quote(k) + (gap ? ': ' : ':') + v); } } } } else { for (k in value) { v = str(k, value, rep); if (v) { partial.push(quote(k) + (gap ? ': ' : ':') + v); } } }
                    v = partial.length === 0 ? '{}' : gap ? '{\n' + gap + partial.join(',\n' + gap) + '\n' + mind + '}' : '{' + partial.join(',') + '}'; gap = mind; return v;
            } 
        }
        return { stringify: function(value, replacer, space) {
            var i; gap = ''; indent = ''; if (space) { if (typeof space === 'number') { for (i = 0; i < space; i += 1) { indent += ' '; } } else if (typeof space === 'string') { indent = space; } }
            if (!replacer) {
                rep = function(key, value) {
                    if (!Object.hasOwnProperty.call(this, key)) { return undefined; }
                    return value;
                };
            } else if (typeof replacer === 'function' || (typeof replacer === 'object' && typeof replacer.length === 'number')) { rep = replacer; } else { throw new Error('JSON.stringify'); }
            return str('', { '': value });
        }, parse: function(text, reviver) {
            var j; function walk(holder, key) {
                var k, v, value = holder[key]; if (value && typeof value === 'object') { for (k in value) { if (Object.hasOwnProperty.call(value, k)) { v = walk(value, k); if (v !== undefined) { value[k] = v; } else { delete value[k]; } } } }
                return reviver.call(holder, key, value);
            }
            if (/^[\],:{}\s]*$/.test(text.replace(/\\["\\\/bfnrtu]/g, '@').replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').replace(/(?:^|:|,)(?:\s*\[)+/g, ''))) { var regEx = /(\"\d{4}-\d{2}-\d{2}T\d{2}:\d{2}.*?\")|(\"\\*\/Date\(.*?\)\\*\/")/g; text = text.replace(regEx, this.regExDate); j = eval('(' + text + ')'); return typeof reviver === 'function' ? walk({ '': j }, '') : j; }
            throw new SyntaxError('JSON.parse');
        }, regExDate: function(str, p1, p2, offset, s) {
            str = str.substring(1).replace('"', ''); var date = str; if (/\/Date(.*)\//.test(str)) { str = str.match(/Date\((.*?)\)/)[1]; date = "new Date(" + parseInt(str) + ")"; }
            else { var matches = str.split(/[-,:,T,Z]/); matches[1] = (parseInt(matches[1], 0) - 1).toString(); date = "new Date(Date.UTC(" + matches.join(",") + "))"; }
            return date;
        }, quote: quote
        };
    } ();
}

用法是这样的:

    var manageProxy = new serviceProxy("/WebServices/ResultStructuresService.svc/");
    manageProxy.invoke("SomeFunction",
        { someparam: somevalue },
        function(message) {

            if (!message) {
                return;
            }
            // the json parameters should be encode to prevent that attack 
            if (message && message.length > 0) {
                // do something with the response
                _allowedTypes = message;
            }
        },
        function(error) {
            $.jGrowl(error.Detail, { header: "Oops!", life: 8000 });
        });
于 2009-08-18T11:30:03.847 回答
3

从长远来看,最好还是使用 jQuery。VS2010 自带 jQuery,我推荐使用它,你不会后悔的。它更干净,有很多插件,而且非常高效。一旦你使用它,也很容易将知识转移到其他平台。

于 2010-04-25T12:24:45.803 回答