怎么封装JS和CSS文件为服务器端控件(2)

分类: asp.net   出处:iocblog整理  更新时间:2009-04-06   添加到收藏  

  再看

 

void Page_PreRenderComplete(object sender, EventArgs e)
   {
   Page.ClientScript.RegisterClientScriptResource(this.GetType(), "Wisesoft.Web.Control.Wisesoft.Calendar.calendar.js");
   }  


  是在页面呈现之前将你的JS文件注册到页面上。
   [Bindable(true)]
   [Category("图标设置")]
   [DefaultValue("imagin/calender.gif")]
   [Localizable(true)]
  是利用反射的元数据信息,来设置属性。就是给你的日期控件旁边加上个小图标,把它做成一个属性,可以让程序员自定义设置图片,也可以把它继承进去。
  好了,这样就可以把JS文件封装好了,再来看看CSS文件如何封装并写入客户端。
  我们可以看见下面有一个方法,

 

   /**//// <summary>
   /// 注样式文件
   /// </summary>
   /// <param name="path"></param>
   private void RegisterCssFile(string path)
   {
   HtmlLink link1 = new HtmlLink();
   link1.Attributes["type"] = "text/css";
   link1.Attributes["rel"] = "stylesheet";
   link1.Attributes["href"] = path;
   this.Page.Header.Controls.Add(link1);
   } 


   
   它就是用来注册你的CSS文件的,大家都知道在我们的页面代码里面是<link href="StyleSheet.css" rel="stylesheet" type="text/css" />引入外部样式文件。这个方法就是达到这个目的。那么我们现在还没有样式文件。
  因此我们就必须建立一个CSS,然后把它设置一下(和JS的设置方式一样)。再到void Page_PreRenderComplete(object sender, EventArgs e)方法调用就可以了,但是还有其他方法,我们来介绍第二种(对JS文件也可以这样使用),建立一个CalendarCSS.cs文件,代码如下:

 

  using System;
  using System.Collections.Generic;
  using System.Text;
  
  namespace Wisesoft.Web.Control
  {
   public class CalenderCSS
   {
   public static string CSS = @"<style type=""text/css"">
   .Wdate{
   border:#999 1px solid;
   height:18px;
   background:url($ImaginURL$) no-repeat right;
   }
   .WdateFmtErr{
   font-weight:bold;
   color:red;
   }
   </style>";
   } (文章来源 www.iocblog.net)
  } 

 
   这个类其实是将我们的CSS文件,写为一个字符串形式,然后供主函数调用,以注册到客户端使用。
  那么我们再看看CalendarBox.cs文件里的这段代码

 

  string calendar = CalenderCSS.CSS;
   calendar = calendar.Replace("$ImaginURL$", this.ImaginURL);
   if (!Page.ClientScript.IsClientScriptBlockRegistered("_calendar"))
   Page.ClientScript.RegisterClientScriptBlock(typeof(string), "_calendar", calendar);  


  它就是将我们已经写好的一段字符串以快的形式注册到客户端(当然还有更多的注册方式,可以在MSDN看看ClientScript类)。
  好了,基本上就可以使用了。编译一下呢?

上一页 [1] [2]


Tag: TextBox ,控件



文章整理:iocblog
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。