博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
防止自建控件与页面间重复引入客户端js脚本的方法
阅读量:6575 次
发布时间:2019-06-24

本文共 2386 字,大约阅读时间需要 7 分钟。

我们在创建自定义的服务器端控件或是用户控件时,经常需要用到一些客户端js脚本,通常将其作为资源嵌入,并在页面后台代码中添加引用,但是如若用到一些通用的js库(比如JQuery)时,就免不了产生一个疑问:

如果使用此控件的页面也需要用到该库时怎么办?

在控件中引入,在页面中也引入,不就会造成页面中引入两次同一个或是两个版本的js库吗?这不仅逻辑不通,而且可能浪费资源。

如是不在控件中引入,但要求页面中必须引入,那么拿给别人使用时免不了让他一头雾水,甚至某一天你自己都忘了这回事,对着一堆js错误挠头。

本文将演示整个编写流程,并提供正确的做法演示:

首先建立一个名为"客户端脚本引用测试"的网站项目(注意是网站项目):

image

接着在解决方案中添加一个服务器控件项目,名为"测试服务器控件":

image

修改测试服务器控件项目中的ServerControl1.cs中的代码,设置Text属性的DefaultValue:

image

更改RenderContents事件实现内容为下面的代码用以输出基本的客户端呈现外观:

 image

output.Write(string.Format(@"<div id=""ZDC""color: #54857D; font-weight: bold; border: 1px solid #CADBDB; background-color: #E8F3FF; text-align: center; line-height: 72px; width: 360px; height: 72px"">

    {0}</div>
<button id=""ZDCS"" name=""Abutton1"">隐现控件</button>",Text));

接下来将JQuery脚本及智能感知注释文件添加到自定义控件项目中:

image

修改JQuery脚本的属性,将生成操作改为嵌入的资源:

image

新建一个act.js,写入下面代码:

/// <reference path="jquery-1.2.6-vsdoc.js" />

$(function() {
    $("#ZDCS").toggle(function() {
        $("#ZDC").hide("fast");
    }, function() {
        $("#ZDC").show("slow");
    });
});

将其文件属性中的生成操作也设为嵌入的资源

 

打开AssemblyInfo.cs:

image

在文件最下面添加下面的代码:

 image

[assembly: WebResource("测试服务器控件.jquery-1.2.6.min.js", "application/x-javascript")]

[assembly: WebResource("测试服务器控件.act.js", "application/x-javascript")]

然后在ServerControl1.cs中添加下面的代码:

 image

protected override void CreateChildControls()

{
    Page.ClientScript.RegisterClientScriptInclude("JQuery", Page.ClientScript.GetWebResourceUrl(this.GetType(), "测试服务器控件.jquery-1.2.6.min.js"));
    Page.ClientScript.RegisterClientScriptInclude("ZDC", Page.ClientScript.GetWebResourceUrl(this.GetType(), "测试服务器控件.act.js"));
    base.CreateChildControls();
}

这样既可完成脚本注册,注意,图中圈出的"JQuery"用于标识脚本,是防止重复引入脚本的关键。

接下来回到网站项目中,添加对引用控件项目的引用:

image

编译一下,然后就可以从工具箱中找到新增的自定义控件了:

image

 

 

 

 

将其添加入网站的默认页面:

image

编译并运行:

点击按钮就可以看到JQuery的隐藏、显示效果。

查看源代码可以看到有两个引用脚本,引用的正是我们在控件中设置的JQuery和act.js:

image

打开第一个引用地址,就可以看到我们在控件中嵌入的1.2.6版本JQuery代码:

image

现在我们假设在页面中的某个功能需要用到1.3.2版JQuery库,而控件中的是1.2.6版,让我们看看如何来将其替代:

首先建立一个JS文件夹,并添加1.3.2版JQuery库:

image

然后在页面的Page_Load事件中添加脚本引用代码:

image

if (!IsPostBack)

{
    ClientScript.RegisterClientScriptInclude("JQuery", "/JS/jquery-1.3.2.min.js");
}

还是注意一定要把标识"JQuery"写对,否则你将会看到两个版本的JQuery都载入你的页面。

编译并运行,JQuery效果仍然正常运行,查看源代码:

image

可以看到第一个脚本引用变成了我们所设的1.3.2版本的文件Url,而不是之前的/WebResource.axd?…………什么的了,打开该路径,看到的也的确是1.3.2版JQuery:

image

 

 

OK,演示到此完毕,我们在此达成了这样的效果:页面中没有引入JQuery时就用控件内嵌的JQuery文件,页面中引入了JQuery就只使用页面中的JQuery。

这样做的好处显而易见:即不会产生错误,也不会浪费资源,还可以随时使用最新版的JQuery库。

本文转自斯克迪亚博客园博客,原文链接:http://www.cnblogs.com/SkyD/archive/2009/06/10/1500074.html,如需转载请自行联系原作者

你可能感兴趣的文章
2018-2019-2 网络对抗技术 20165318 Exp1 PC平台逆向破解
查看>>
关于图片或者文件在数据库的存储方式归纳
查看>>
hihocoder 1014 Trie树
查看>>
ADO.NET笔记——使用DataSet返回数据
查看>>
MOTO XT702添加开机音乐
查看>>
Python脚本日志系统
查看>>
B0BO TFS 安装指南(转载)
查看>>
gulp常用命令
查看>>
TCP(Socket基础编程)
查看>>
RowSet的使用
查看>>
每日一记--cookie
查看>>
WPF and Silverlight 学习笔记(十二):WPF Panel内容模型、Decorator内容模型及其他...
查看>>
MySQL:创建、修改和删除表
查看>>
Java多线程程序设计详细解析
查看>>
IOS 7 Study - UISegmentedControl
查看>>
八、通用类型系统
查看>>
JQuery的ajaxFileUpload的使用
查看>>
Java分享笔记:使用keySet方法获取Map集合中的元素
查看>>
Java面向对象练习题之人员信息
查看>>
关于Integer类中parseInt()和valueOf()方法的区别以及int和String类性的转换.以及String类valueOf()方法...
查看>>