好吧,我终于完成了它。
- 我们最终创建了带有一些代码的Page Descendant来代替脚本管理器(见下文)。我们使用控件的Page属性从控件的OnPreRender方法调用它。感谢来自http://dj.codeplex.com/的人提供了如何做到这一点的例子。
2,3,4.我们使用jQuery.data方法将脚本类的实例绑定到DOM元素。我们使用jQuery.ready方法执行实例化,初始化和绑定代码。这段代码被添加到使用AddScript方法的Render方法中进行控制(参见下文)。也许以后我们会使用JavaScriptSerializer将C#控件的值传递给JavaScript类,但目前我们通过手动传递参数给JavaScript类构造函数。
HashSet<string> scriptReferences = new HashSet<string>();
HashSet<string> cssReferences = new HashSet<string>();
List<string> styles = new List<string>();
public void AddScriptReference(string url, bool resolve)
{
string realUrl = url;
if (resolve)
realUrl = ResolveClientUrl(url);
if (!scriptReferences.Contains(realUrl))
{
scriptReferences.Add(realUrl);
Header.Controls.Add(
new LiteralControl(
"<script type='text/javascript' src='" +
realUrl + "'></script>"));
}
}
public void AddCssReference(string url)
{
if (!cssReferences.Contains(url))
{
cssReferences.Add(url);
HtmlLink link = new HtmlLink();
//link.Href = ResolveClientUrl("~/jQuery-ui/css/ui-lightness/jquery-ui.css");
link.Href = url;
link.Attributes.Add("type", "text/css");
link.Attributes.Add("rel", "stylesheet");
Header.Controls.Add(link);
}
}
public void AddCssStyle(string style)
{
styles.Add(style);
}
protected override void OnPreRenderComplete(EventArgs e)
{
base.OnPreRenderComplete(e);
Header.Controls.Add(
new LiteralControl(
"<style type='text/css'>" + styles.Join("\n") + "</style>"
)
);
}
public static void AddScript(HtmlTextWriter writer, string script,
bool executeWhenReady)
{
writer.AddAttribute(HtmlTextWriterAttribute.Type, "text/javascript");
writer.RenderBeginTag(HtmlTextWriterTag.Script);
if (executeWhenReady)
{
writer.Write("$(function(){\n");
}
writer.Write(script);
if (executeWhenReady)
{
writer.Write("});\n");
}
writer.RenderEndTag();
}
对不起,我不明白它将如何帮助我摆脱ASP.NET AJAX。 –
这解决了你陈述的问题“它膨胀了,我们不使用UpdatePanel”。新框架(如发布的链接中所述)解决了这些问题。 –