博客
关于我
MasterPage(母板页)的不一般用法
阅读量:801 次
发布时间:2023-02-07

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

在ASP.NET项目中,通常我们会在页面前面添加编译指令来指定母板页。然而,通过page对象的MasterPageFile属性动态指定母板页也是一个可行的方法。这种方式通常在PreInit事件中进行配置。例如,可以在BasePage类的构造函数中添加事件处理程序:

public class BasePage : Page{    public BasePage()    {        PreInit += Set_MasterPage;    }    private void Set_MasterPage(object sender, EventArgs e)    {        this.MasterPageFile = Request.Path + @"../jj.Master";    }}

继承自BasePage类的页面将使用jj.Master作为母板页。这种方式的优势在于,只需改变一处代码即可更换母板页,每个母板页对应一个继承自Page类的自定义页面类。

在母板页的代码文件中,可以定义各种字段和属性供前端模板使用。这种方式可以实现链接和路径的分离,便于开发和部署。即使大段内容也可以分离,例如:

protected TemplateInfo TemplateInfo{    get { return TemplateInfo.Instance; }}

通过Singleton模式,可以将模板信息存储在单例中:

public class TemplateInfo{    private static readonly TemplateInfo Instance = new TemplateInfo();    public static TemplateInfo Instance    {        get { return Instance; }    }    private static DateTime scriptTempLastTime;    private static string scriptHtml;    public static string ScriptHtml    {        get        {            string path = "";            DateTime lastDT = File.GetLastWriteTime(path);            if (scriptTempLastTime < lastDT || string.IsNullOrEmpty(scriptHtml))            {                scriptTempLastTime = lastDT;                scriptHtml = File.ReadAllText(path);            }            return scriptHtml;        }    }}

这种方法的优势是,母板页的变化量可以分离到外部文件中,便于维护和部署。

转载地址:http://hzyfk.baihongyu.com/

你可能感兴趣的文章
Openlayers中点击地图获取坐标并输出
查看>>
Openlayers中设置定时绘制和清理直线图层
查看>>
Openlayers图文版实战,vue项目从0到1做基础配置
查看>>
Openlayers实战:modifystart、modifyend互动示例
查看>>
Openlayers实战:判断共享单车是否在电子围栏内
查看>>
Openlayers实战:加载Bing地图
查看>>
Openlayers实战:绘制图形,导出geojson文件
查看>>
Openlayers实战:绘制图形,导出KML文件
查看>>
Openlayers实战:绘制多边形,导出CSV文件
查看>>
Openlayers实战:绘制带箭头的线
查看>>
Openlayers实战:自定义放大缩小,显示zoom等级
查看>>
Openlayers实战:自定义版权属性信息
查看>>
Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
查看>>
Openlayers实战:选择feature,列表滑动,定位到相应的列表位置
查看>>
Openlayers实战:非4326,3857的投影
查看>>
Openlayers高级交互(1/20): 控制功能综合展示(版权、坐标显示、放缩、比例尺、测量等)
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(12/20):利用高德逆地理编码,点击位置,显示坐标和地址
查看>>
Openlayers高级交互(13/20):选择左右两部分的地图内容,横向卷帘
查看>>