ASP.NET CMS模板培训教程

注意:此文档中出现所有的类,都是公司内部的,也就是说,只是给公司内部人员培训的一篇文章而已,如果其他的人看到了,

看不懂里面的类,那是因为这都是我公司内部的框架。

首先是进入我们的系统的后台,然后选择相对应的站点。

 

 

这样就可以在对应的站点下面,去进行对应的的操作了。

本文只会去解释一些基础的功能。

站群管理

站点管理

如下图所示:

 

这个是建立站点,上图显示了几个站点那么这里就有几个站点。

我们随便打开一个站点来做解释,其中*号的是必填项:

站点名称:站点的名称

站点标题:英文字母组成

虚拟目录:在服务器上的虚拟目录的名称(不可重名)

站点网址:英文名称,访问站点的地址,比如一个站点叫WWW.XXX.COM,子站点地址为NHXC,则这个网站的访问地址为wwww.xxx.com/NHXC

IIS设置:一般选择第一个,因为为虚拟目录(上面设置过)

注意:为了以后维护方便,建议把站点标题,虚拟目录,站点网址设为同样的。

 

 

信息类别

这里的信息类别是和栏目相关的,这里做一下简单的介绍。

这里的信息类别,和站点设计下的栏目管理下的一一对应。

稍后会讲到这个信息类别的作用。

下面是信息类别的界面,唯一需要注意的地方就是父类别别选错了,要注意下

此类别下的后面几个功能因为很少用到,暂时不做介绍

站点设计

栏目管理

下面是概览图

 

下面就几个基本的功能点进行介绍:

新增栏目:在当前选择的栏目下新增子栏目

栏目标题:栏目的标题

关联类别:里面有类别,专题,推荐,头版头条等,一般情况下选择"类别",

选择类别以后,右边的按钮由灰色变成可选状态,单击选择按钮,如下图,选择对应的类别,这个类别,就是站群管理下信息类别里新增的类别,记得要一一对应哦。

 

设置好了类别以后就会出现如下的界面。

可以看到信息类别和栏目是一一对应的

 

设置栏目模板:设置栏目的显示所用到的模板,后面的模板章节会提到。下面为预览图:

设置内容模板:设置此栏目下的文章的内容所对应的模板,下面为预览图:

 

其中的分配按钮和设置栏目模板是一个意思,内容模板一样的

 但是有一点要记住,如果你新建了一个栏目,要把这个栏目显示出来,必须分配栏目模板和内容模板,这点要记住。

 

模板编辑

这是是重中之重,也是会最详细解释的一个地方。

这么多模板,是不是眼花了呢,别急,我的打算是结合模板的实例来进行代码的讲解。

下面开讲吧:

新增:新增一个模板文件夹

修改:修改模板文件夹的名称

删除:删除一个模板文件夹(注意:这里如果删除了文件夹,文件夹下的模板都会被删除,删除前一定要慎重考虑,因为没了模板文件,网站会显示不出来)

排序:给文件夹排序

新增模板:在选中的文件夹中新增一个模板文件。

删除模板:删除一个模板文件。

 我们随便打开一个文件夹,比如改版热点专题下面的天心文明创建,我们就可以打开相应的文件夹并查看里面的模板文件。

点一下预览按钮的话,会弹出新窗口,可以进行模板的预览,不然我们点击这个天心文明创建首页模板。

 

想要编写模板,我们首先需要了解哪些东西是动态生成的,哪些是静态的。只有明白了哪些是动态生成的,我们才能编写出自己需要的模板。

如下图:

1,2,3,4我已经标示出来了,当然还有更多的模块,我这里只是做一个示例而已。我们来分析一下下面一张图。

1.很明显是一个导航栏,这个导航栏对应着“栏目”,也就是说在这个大栏目下的一些子栏目,我在后台添加了哪些栏目,这里就会显示哪些栏目。

2.图片导航栏:对应着某个栏目下的文章的一个图片的跳转URL(后面会提到),后面会做详细的介绍。

3.很明显,就是一个文章的列表,列出了这个栏目下的文章有哪些,后面跟着日期,4和3类似,就不一一介绍了

 

下面开始介绍一下,模板的具体编写,我先把功能点一一罗列出来,我们再用几个例子来结束。

选择天心文明创建,点击新增模板。

打开新增模板对话框。

选择模板:如果你把一个模板写好了,想嵌套到另一个页面里面(比如首页),你就可以选择模板,说白一点,就是把你选择的模板里的内容100%的原封不动的嵌套到其他的文件里,当然你也可以选择不用模板,但是,这样维护起来就很困难了哦~~

选择好模板以后,点击插入按钮,就可以插入一段模板代码了。

代码如下:

<%=Include( "~/模板文件夹/改版热点专题/天心金融/机构职责数据源.tpl" )%>

这在首页里很常见哦,下面我先贴一段首页模板的代码出来大家就懂了。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
<title>天心文明创建</title>
<link rel="stylesheet" type="text/css" href="~/txwmcj/css/style.css"/>

<script type="text/javascript" src="~/txwmcj/js/jquery.js"></script>

</head>

<body>
    <div class="header"><img src="~/txwmcj/images/hbg.jpg" width="1002" height="296" title="" /></div>
<div  align="center">
<img src="~/images/banner1.jpg" width="1000" height="90" />
</div>
    <div class="imenu">
        <ul>
         <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/首页菜单导航栏.tpl" )%>
            </ul>
    </div>
    
    <div class="content">
        <div class="conDiv">
        <!-------one---------->
             <div class="cdiv">
             
                <div class="showimg rightbox">
                    <!--  <img START>-->           
                     <div id="slideBox">
                    
   <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/图片新闻数据源.tpl" )%>        
                                              
                    </div>
                    <!--  <img END>-->
                </div>
                    
              
                
                <div class="bobao">

<%=Include( "~/模板文件夹/改版热点专题/天心文明创建/文明播报数据源.tpl" )%>
                   
                </div>
                
                <div class="jieri">
                    <div class="jieri_info">
<%=Include( "~/模板文件夹/改版热点专题/天心文明创建/我们的节日数据源.tpl" )%>
                  </div>
                    <div class="av2">
                        <a href="~/Intercourse/LeadMail/Default.aspx" target="_blank"><img src="~/txwmcj/images/img1.jpg" width="234" height="64" title="" /></a>
                        <a href="~/i/27a29abfe4e242b59fd8e8b65dc0ee.html" target="_blank"><img src="~/txwmcj/images/img2.jpg" width="234" height="64" title="" /></a>
                    </div>
                </div>
             </div>
        <!-------one--end-------->
         <!-------2---------->
             <div class="cdiv">
             <!--cdivLeft-->
                 <div class="cdivLeft">
                    <div class="av"><img src="~/txwmcj/images/av2.jpg" width="660" height="52" title="" /></div>
                   
                    <div class="item">
                         <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/文明城市数据源.tpl" )%>
                        
                    </div>
                    <div class="item">
                        
<%=Include( "~/模板文件夹/改版热点专题/天心文明创建/文明村镇数据源.tpl" )%>
                      
                    </div>
                     <div class="item">
<%=Include( "~/模板文件夹/改版热点专题/天心文明创建/文明单位数据源.tpl" )%>                        
                    </div>
                     <div class="item">
<%=Include( "~/模板文件夹/改版热点专题/天心文明创建/文明社区数据源.tpl" )%>
                    </div>
                </div>
              <!--cdivLeft--end-->
              <!--cdivRight-->   
                <div class="cdivRight">
                    <div class="news">
                        <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/通知公告数据源.tpl" )%>
                    </div>
                    <div class="news">
                        <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/道德模范数据源.tpl" )%>
                    </div>
                    <div class="news" style=" background:url(~/txwmcj/images/box4.jpg) no-repeat;">
                        <%=Include( "~/模板文件夹/改版热点专题/天心文明创建/志愿服务数据源.tpl" )%>
                    </div>
                </div>
                <!--cdivRight--end-->
                
             </div>
        <!-------2--end-------->
        <div class="foot">
            <center>
     <p>主办单位:天心区人民政府  承办单位:天心区人民政府电子政务管理办公室  联系电话:0731-85899000</p>
    <p>备案序号:湘ICP备09003224号 最佳使用效果:1024*768分辨率/建议使用微软公司IE6或以上</p>
            </center>
        </div>
        </div>
    </div>
    
<script type="text/javascript" src="~/txwmcj/js/showbox.js"></script>
</body>
</html>
首页代码

这种插入模板的方式在首页里是随处可见的

 选择栏目:说白一点,就是得到你选择的栏目的一个“对象”,相当于ASP.NET中的一个填充数据的实体类,你可以这么理解,里面有很多方法,当然不仅仅是实体类那么 简单,后面会说到,我们先来实现一下效果。

一路确定以后,就会实现如下代码:

IIndex index = Siter.GetIndex( "0076381d87694876b29858d2e806c4" ); //获取栏目[合同信用]

其中的0076381d87694876b29858d2e806c4是栏目的ID,每个栏目对应了一个独一无二的ID。

为了大家理解代码方便,我先来介绍下代码吧。

点击帮助按钮,会出现代码,鼠标移动到上面,有详细的信息显示。

 

 
Siter 站点对象
属性  
Title Siter.Title(站点的标题)
方法(相对于Siter)  

IIndex index = Siter.GetIndex( indexId );

从SITER对象中得到ID为indexId的索引(通常为栏目)

 

IIndex index = Siter.GetIndex( indexId , "parent" , 1 );

得到ID为indexId的索引的父级索引,其中1为深度,比如:

我->爱->爸->妈,indexId为妈,按照上述规则1,得到的是爸,2得到的是爱,以此类推。

IIndex[] index = Siter.GetIndexs( 0 );

获得指定深度的所有集合,-1表示所有子集,0表示本身,大于0的数字表示到指定深度的集合

比如:我->爱->爸->妈,表示从站点对象开始,如果为-1,将得到所有子集包括本身,依次类推。

GetIndexs( deep , count )

IIndex[] index = Siter.GetIndexs( 0 , -1 );

同上,需要注意的是count是指定获取的数量的数据,比如获取的每一级栏目下面有5篇文章

,这里COUNT写3,那么只能获取到前三条文章,-1为全部。

IIndex[] indexs = Siter.GetIndexs( indexId );

获取指定索引的栏目的所有子集

注意:GetIndex( indexId )是获取当前索引,GetIndexs( indexId )是获取当前索引的子集的索引的集合。

同上,DEEP为指定子集的深度。
,只是指定了每一级所获取的文章数目的个数,-1为不限制
 

 IIndex index = Siter.GetCurrentIndex();

获得当前的索引

 当然这里只是列出了一部分方法,具体的含义可以自行查看,这里就不累赘了。

下面用几个例子来说明下模板的基本用法。

1.通知公告数据源

<%IIndex index = Siter.GetIndex( "92766cbbbb1344449038a742f8c087" ); //获取栏目[通知公告]
%>
<div class="title"><h3><%=index.Title%></h3><a href="<%=index.FileUrl%>">更多>>&nbsp;</a></div>
           <ul>
<%
IContent[] contents = index.GetContents( -1 , 5 );
    if ( contents != null )
    {
    for( int i = 0 ; i < contents.Length ; i++ )
    {

        string newTitle="";
        newTitle = contents[i].Title.Length >16 ? ( contents[i].Title.Substring (0,15)+"..." ) : contents[i].Title;
%>
    <li><a href="<%=contents[i].FileUrl%>"><%=newTitle%></a></li>
<%
}
    }
%>

</ul>
通知公告数据源
<%IIndex index = Siter.GetIndex( "92766cbbbb1344449038a742f8c087" ); //获取栏目[通知公告]
%>

  上面的代码是获得指定的栏目的索引对象

下面的代码中的index.Title是获取当前索引的名称,而index.FileUrl则是获取当前对象的URL链接地址

<div class="title"><h3><%=index.Title%></h3><a href="<%=index.FileUrl%>">更多>> </a></div>

  下面的代码则是从当前索引中,获取里面的文章的内容,第一个参数为“深度”,-1为所有子集的深度,5为获取的文章的数目

一般来说,我们有这么一个习惯,如果要取里面的文章的话,那么这个索引是没有子集的,也就是他是最终的叶子节点,当然了,这个没有硬性规定,看自己的喜欢而定。

后面的就是从文章里循环取出来其中做了字符长度的判断,如果标题大于16个字符,那么就省略后面的。

<%
IContent[] contents = index.GetContents( -1 , 5 );
	if ( contents != null )
	{
	for( int i = 0 ; i < contents.Length ; i++ )
    {

		string newTitle="";
		newTitle = contents[i].Title.Length >16 ? ( contents[i].Title.Substring (0,15)+"..." ) : contents[i].Title;
%>
	<li><a href="<%=contents[i].FileUrl%>"><%=newTitle%></a></li>
<%
}
	}
%>

  

下面的例子我都会挑选一些不同的地方跟大家分享。

 <%
IIndex index = Siter.GetIndex( "f1ec687464194616af647968d0477d" ); //获取栏目[图片新闻]
IContent[] contents = index.GetContents( "Sort" );
int len = contents == null ? 0 : ( contents.Length > 5 ? 5 : contents.Length );

%>


                        <ul id="show_pic" style="left:0px">
<%
    for( int i = 0 ; i < len ; i++ )
    {
%>


<li><a href="<%=contents[i].FileUrl%>"><img src="<%=contents[i].Get( "JumpUrl" )%>" height="200" width="282" title="<%=contents[i].Title%>" /></a></li>
<%
    }
%>
                        </ul>
                        <ul id="iconBall">
<%
    for( int i = 0 ; i < len ; i++ )
    {
%>

                            <li class="active"><%=i+1%></li>
<%
    }
%>

                        </ul>
                        
                        <ul id="textBall">
<%
    for( int i = 0 ; i < len ; i++ )
    {
%>
                            <li class="active"><%=contents[i].Title%></li>

<%
    }
%>

                        </ul>

<div class="show_gd"><a href="<%=index.FileUrl%>">更多</a></div>
图片新闻数据源

上面的是另一个数据源,图片新闻。

其中大部分和上面的例子都是相同的,有几点需要注意下:

contents[i].Get( "JumpUrl" )

获取到的是数据库列为JumpUrl中存放的数据。那么这个JUMPURL在哪呢?我放张图。

就是在编辑或者新增文章里面的跳转URL的内容。

int len = contents == null ? 0 : ( contents.Length > 5 ? 5 : contents.Length );

这里得到的文章的数目(指定索引下)。

其他的地方,按照需求来写,具体的就不一一累赘了。

还有,有的数据源需要带当前时间,可以这么写

<%=contents[i].Get<DateTime>( "newsdate" ).ToString( "yyyy-MM-dd" )%>

  下面来给大家介绍一些通用的已经写好的重用性强的模板。

下面的代码的意思是:

如果是首页,那么显示首页标题

如果是栏目页,显示当前栏目标题+首页标题

如果是内容页,显示当前文章标题+首页标题

<%
    string s = "";
    if( this.Content == null && this.Index == null )
    {
        s = "天心区公众信息网";
    }
    else if( this.Content == null && this.Index != null )
    {
        s = this.Index.Title + " - " + "天心区公众信息网";
    }
    else if( this.Content != null )
    {
        s = this.Content.Title + " - " + "天心区公众信息网";
    }
%>

 

下面是分页代码,也很有用的

 

<table width="711" border="0" cellspacing="0" cellpadding="0">
<tr>
  <td height="36" background="~/public/images/kuan_top.gif"><table width="100%" border="0" cellspacing="0" cellpadding="0">
    <tr>
      <td width="6%">&nbsp;</td>
      <td width="94%" align="left" class="font3"><%=this.Index.Title%></td>
    </tr>
  </table></td>
</tr>
<tr>
    <td background="~/public/images/kuan_bg.gif"><table width="95%" border="0" align="center" cellpadding="0" cellspacing="0">
    <%
        IContent[] contents = Index.GetContents( -1,-1 );
        if ( contents != null )
        {
            Pager.LoadContents( contents , 10 );
            for( int i = Pager.DataBegin ; i < Pager.DataEnd ; i++ )
            {
        
                    IPage childPage = Pager.GetContentsPage( i );
                    IContent content = childPage.GetContent();
                        if ( content.Text.IndexOf ("<img") > -1 )
                        {

    %>
                        <tr>
                          <td align="center" class="bottom-line"><img src="~/public/images/dot2.gif" width="9" height="9" /></td>
                          <td height="30" align="left" class="bottom-line" ><a href="<%=content.FileUrl%>"><%=content.Title%></a>&nbsp;<img src="~/public/images/ico_picnews.gif" width="16" height="16" /></span></td>
                          <td align="right" width="100" class="bottom-line"><span class="hui"><%=content.Get<DateTime>( "newsdate" ).ToString( "yyyy-MM-dd" )%></span></td>
                        </tr>
    <%
                        }
                        else
                        {
    %>
                        <tr>
                          <td align="center" class="bottom-line"><img src="~/public/images/dot2.gif" width="9" height="9" /></td>
                          <td height="30" align="left" class="bottom-line" ><a href="<%=content.FileUrl%>"><%=content.Title%></a></span></td>
                          <td align="right" width="100" class="bottom-line"><span class="hui"><%=content.Get<DateTime>( "newsdate" ).ToString( "yyyy-MM-dd" )%></span></td>
                        </tr>
    <%
                        }

            }
    %>
    </table>
    <table width="95%" border="0" align="center" cellpadding="0" cellspacing="0">
        <tr>
        <td>&nbsp;</td>
        </tr>
        <%
            if ( Pager.PageCount >1 )
            {
        %>
        <tr>
        <td height="28" align="center" bgcolor="f3f3f3">
            共有<%=Pager.DataCount%>条信息;每页<%=Pager.PageSize%>条信息;当前第<span class="red-14"><%=Pager.PageIndex + 1%></span>页/共<%=Pager.PageCount%>页;</br>
            <a href="<%=Pager.First%>">首页</a>
            <a href="<%=Pager.Previou%>">上一页</a>
            <select name="select" id="Select" onchange="javascript:this.selectedIndex > 0 ? (window.open( this.options[this.selectedIndex].value )) : ‘‘;" style="width:100px">
            <option selected>- 请选择页数 -</option>
            <%
                for( int i = 0 ; i < Pager.PageCount ; i++ )
                {
                    IPage childPage = Pager.GetContentsPage( i );
            %>
                <option value="<%=childPage.FileUrl%>"><%=i+1%>页</option>
                                     <!--<a href="<%=childPage.FileUrl%>"><%=i+1%></a>&nbsp;-->
            <%
                }
            %>
            </select>
            <a href="<%=Pager.Next%>">下一页</a>
            <a href="<%=Pager.Last%>">尾页</a>
        </td>        </tr>
        <%    
            }
        %>
        <tr>
        <td>&nbsp;</td>
        </tr>
        <%
        }
        %>
    </table>
    </td>
</tr>
<tr>
  <td><img src="~/public/images/kuan_bottom.gif" width="711" height="14" /></td>
</tr>
        
        
分页

原理如下:首先得到当前INDEX下的所有文章,然后再使用分页对象Pager把每次载入的分成N份,比如10份

Pager.LoadContents( contents , 10 );

然后再去循环里面的每一页,注意,要用它给的方法哦。

然后用

IPage childPage = Pager.GetContentsPage( i );IContent content = childPage.GetContent();得到每一页的内容,

其中的IContent就是你要获取到的具体的数据。另外具体的代码,自己可以多实践。这里只讲几个关键点。

还有一点要特别注意:就是对象的命名的话,比如有2个不同的IContent在同一作用域下必须不同,否则就会报错,

就算是在不同的模板中也不行,因为模板虽然不同,但是拼凑起来的是一体的。

模板就介绍到这里了,如果有不懂的地方,参见“南湖新城”里面的模板,这个相对容易点而且有代表性。

 

站点模板关联

首先如下图

这个和栏目管理当中的分配模板是一个意思,唯一不同的,就是这个可以批量分配,从而节约时间。

点击分配以后,会出现如下提示。

是:重设所有模板。

否:只设置未分配的模板。

 

文档管理

这一块只做一个简单的介绍。

无非就是文章的发布,保存,审核等操作,一目了然咯~~

唯一要注意的是所有文章都可以在文档编辑(全局)里找到哦

 

其他的操作因为暂时用不到,所以暂时就不一一介绍了,以后如果有需要会补充本篇文章。

 最后来一张图:

    

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。