在Asp.Net开发时,用到的JS库、通用的CSS等,在许多页面都会用到,而每次都需要手动引入,相当麻烦,而且有时一旦忘了引用,还得找半天才能找到问题。那有没有什么办法能够一劳永逸的呢?答案是有的。

我们知道Asp.Net是可以通过后台来渲染前端的,所以如果能够在渲染时将所要的js库和css等添入就可以了。而为了能够复用,所以需要进行类的继承。我们写一个Page的基类PageBase,代码如下。

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.UI;
  6. using System.Web.UI.HtmlControls;
  7. using System.Text;
  8. namespace AspNetLoadJsCss.Common
  9. {
  10. public class PageBase : System.Web.UI.Page
  11. {
  12. public static readonly string SCRIPT_INCLUDE_TEMPLATE = "<script src=\"{0}\" type=\"text/javascript\"></script>\r\n";
  13. public static readonly string STYLE_INCLUDE_TEMPLATE = "\r\n<link href=\"{0}\" rel=\"stylesheet\" type=\"text/css\"/>\r\n";
  14. public static readonly string SCRIPT_CONTENT_TEMPLATE = "<script type=\"text/javascript\">{0}</script>\r\n";
  15. protected void Page_InitComplete(object sender, EventArgs e)
  16. {
  17. LiteralControl viewportControl = new LiteralControl();
  18. viewportControl.ID = "viewport";
  19. viewportControl.Text = "\r\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />";
  20. this.Header.Controls.AddAt(GetNextControlIndex(this), viewportControl);
  21. LiteralControl jqueryCssControl = new LiteralControl();
  22. jqueryCssControl.ID = "/jquery.mobile-1.4.4.min.css";
  23. jqueryCssControl.Text = String.Format(STYLE_INCLUDE_TEMPLATE, "/css/themes/default/jquery.mobile-1.4.4.min.css");
  24. this.Header.Controls.AddAt(GetNextControlIndex(this), jqueryCssControl);
  25. LiteralControl myCssControl = new LiteralControl();
  26. myCssControl.ID = "/my.css";
  27. myCssControl.Text = String.Format(STYLE_INCLUDE_TEMPLATE, "/css/my.css");
  28. this.Header.Controls.AddAt(GetNextControlIndex(this),myCssControl);
  29. String jsPath = "/js/jquery.js";
  30. this.ClientScript.RegisterStartupScript(this.GetType(),
  31. "jquery",
  32. String.Format(SCRIPT_INCLUDE_TEMPLATE, jsPath),
  33. false);
  34. jsPath = "/js/jquery.mobile-1.4.4.min.js";
  35. this.ClientScript.RegisterStartupScript(this.GetType(),
  36. "jquery.mobile",
  37. String.Format(SCRIPT_INCLUDE_TEMPLATE, jsPath),
  38. false);
  39. jsPath = "/js/default.js";
  40. this.ClientScript.RegisterStartupScript(this.GetType(),
  41. "default",
  42. String.Format(SCRIPT_INCLUDE_TEMPLATE, jsPath),
  43. false);
  44. }
  45. /// <summary>
  46. /// 取得下一个控件的位置
  47. /// </summary>
  48. /// <returns></returns>
  49. private static int GetNextControlIndex(Page page)
  50. {
  51. int index = 0;
  52. // 如果存在自定义(以CONTROL_ID_PREFIX开头)的控件,则返回最后一个自定义控件的下一个位置
  53. // 如果不存在自定义的控件,则返回<title>的下一个位置
  54. bool startControlBlock = false;
  55. int titleIndex = 0;
  56. String CONTROL_ID_PREFIX = "";
  57. foreach (Control c in page.Header.Controls)
  58. {
  59. if (c is HtmlTitle)
  60. {
  61. titleIndex = index;
  62. }
  63. if (c.ID != null && c.ID.StartsWith(CONTROL_ID_PREFIX))
  64. {
  65. startControlBlock = true;
  66. }
  67. else
  68. {
  69. if (startControlBlock)
  70. {
  71. break;
  72. }
  73. }
  74. index++;
  75. }
  76. int retIndex = startControlBlock ? index : titleIndex + 1;
  77. if (retIndex < 0)
  78. {
  79. retIndex = 0;
  80. }
  81. else if (retIndex >= page.Header.Controls.Count)
  82. {
  83. retIndex = page.Header.Controls.Count - 1;
  84. }
  85. return retIndex;
  86. }
  87. protected virtual void Page_Load(object sender, EventArgs e)
  88. {
  89. }
  90. }
  91. }

注:

1.在页面初始化完成的时候载入相应的JS和CSS文件,所以在Page_InitComplete中实现代码。

2.对于CSS文件需要添加到header中,所以使用Header来添加LiteralControl的CSS控件。

3.对于JS文件,使用注册的方式来载入。

4.如果需要载入一些通用的JS函数或者CDATA,也可以考虑这种方式。

有了PageBase页面之后,对于需要加载这些JS和CSS的页面,就可以直接继承于PageBase,然后重载Page_Load函数,其他的就是正常的写法了。比如

Test页面的后端代码

  1. public partial class Test: PageBase
  2. {
  3. protected override void Page_Load(object sender, EventArgs e)
  4. {
  5. }
  6. }

Test页页的前端代码

  1. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Test.aspx.cs" Inherits="AspNetLoadJsCss.Test" %>
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head runat="server">
  5. <title></title>
  6. </head>
  7. <body>
  8. <form id="form1" runat="server">
  9. </form>
  10. </body>
  11. </html>

渲染后的HTML页面

可以看到CSS和JS都已经载入了。

Asp.Net之后台加载JS和CSS的更多相关文章

  1. 动态加载js和css

    开发过程中经常需要动态加载js和css,今天特意总结了一下常用的方法. 1.动态加载js 方法一:动态加载js文件 // 动态加载js脚本文件 function loadScript(url) { v ...

  2. 动态加载js、css 代码

    一.原生js: /** * 加载js和css文件 * @param jsonData.path 前缀路径 * @param jsonData.url 需要加载的js路径或css路径 * @param ...

  3. 动态加载js和css的jquery plugin

    一个简单的动态加载js和css的jquery代码,用于在生成页面时通过js函数加载一些共通的js和css文件. //how to use the function below: //$.include ...

  4. PHP:如果正确加载js、css、images等静态文件

    日常中,我们想要把一些静态页面放在框架上或者是进行转移时,那么静态页面上的原url加载js.css.images都会失效,那么我们应该怎么进行修改捏? 现在仓鼠做个笔记哈 这里有几个注意项: 1.路径 ...

  5. js插件动态加载js、css解决方案

    最近因为工作需要做了一个js自动导入的插件,一开始很天真的以为动态创建个script添加到head中就ok了,试了之后才发现了问题,就是如果同时引入了多个js文件,而且后一个文件中用到了前一个文件中的 ...

  6. 经验总结:按需加载JS和css

    项目中做过这样的事情:所有页面都通过SSI指令 include这样一份public-js.shtml, 用来引入涉及到的js(包括公共的脚本 验证插件 自定义组件等),但是一些没有交互效果的页面根本不 ...

  7. Yii2 灵活加载js、css

    Yii2.0对于CSS/js 管理,使用AssetBundle资源包类. 视图如何按需加载CSS/JS ? 资源包定义: backend/assets/AppAsset.PHP <?php na ...

  8. 移动端性能优化动态加载JS、CSS

    JS CODE (function() { /** * update: * 1.0 */ var version = "insure 1.1.0"; var Zepto = Zep ...

  9. JavaScript(第二十二天)【动态加载js和css】

    学习要点: 1.元素位置 2.动态脚本 3.动态样式 本章主要讲解上一章剩余的获取位置的DOM方法.动态加载脚本和样式.   一.元素位置 上一章已经通过几组属性可以获取元素所需的位置,那么这节课补充 ...

随机推荐

  1. initWithNibName&initWithCoder &awakeFromNib&UIView常见属性方法

    第一.initWithNibName这个方法是在controller的类在IB中创建,但是通过Xcode实例化controller的时候用的. 第 二.initWithCoder 是一个类在IB中创建 ...

  2. 采用指数退避算法实现ajax请求的重发,全部完成时触发回调函数

    目录: 0.Chrome扩展开发(Gmail附件管理助手)系列之〇——概述 1.Chrome扩展开发之一——Chrome扩展的文件结构 2.Chrome扩展开发之二——Chrome扩展中脚本的运行机制 ...

  3. html5新增选择器

    分享点html5的学习笔记,比较基础,突然发现通过写博客来记笔记有很多优点呢,平常记得笔记比较简单,复习起来比较吃力,看自己的博客理解起来还比较轻松,而且只有真正理解了才能表达清楚让别人看懂,还锻炼语 ...

  4. C#异步编程一

    前几天把Code First系列总结完,想着下步总结什么,原本想着XML,不过XML的内容比较多,还有3天班就中秋节了,想在中秋节前在完成一个系列,所以决定把异步这块总结下.说起异步可能会认为就是多线 ...

  5. 最新微信小程序(应用号)视频教程,实战教程

    1.1课程介绍,定个小目标            http://v.youku.com/v_show/id_XMTc2NzIwNDk1Ng==.html 1.2开发文档简读,了解全貌       ht ...

  6. [BZOJ1856][SCOI2010]字符串(组合数学)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1856 分析:http://www.cnblogs.com/jianglangcaiji ...

  7. [bzoj2245][SDOI2011]工作安排(费用流)

    题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2245 分析: 要注意到题目下面说的w是单增的 明显的费用流: 弄个源点S,汇点T S连 ...

  8. asp.net 学习

    1.维护数据库的完整性.一致性.你喜欢用触发器还是自写业务逻辑?为什么? 答:尽可能用约束(包括CHECK.主键.唯一键.外键.非空字段)实现,这种方式的效率最好:其次用触发器,这种方式可以保证无论何 ...

  9. struts2面试题汇总

    一.工作原理 一个请求在Struts2框架中的处理大概分为以下几个步骤 1 客户端初始化一个指向Servlet容器(例如Tomcat)的请求 2 这个请求经过一系列的过滤器(Filter)(这些过滤器 ...

  10. 【CodeForces 472A】Design Tutorial: Learn from Math

    题 题意:给你一个大于等于12的数,要你用两个合数表示出来.//合数指自然数中除了能被1和本身整除外,还能被其他的数整除(不包括0)的数. 分析:我们知道偶数除了2都是合数,给你一个偶数,你减去一个偶 ...