opencms templatetwo学习

modulestwo中的main.jsp的构建过程
第一步构建头部区域
<head>
<title><cms:property name="Title" file="search" /></title>
<meta name="description" content="<cms:property name="Description" file="search" />" >
<meta name="keywords" content="<cms:property name="Keywords" file="search" />" >
<meta http-equiv="Content-Type" content="text/html; charset=<cms:property name="content-encoding" file="search" default="<%= OpenCms.getSystemInfo().getDefaultEncoding() %>"/>" >
<meta name="robots" content="index, follow" >
<meta name="revisit-after" content="7 days" >

<!-- insert stylesheets needed for the template -->
<c:forEach items="${cms.stylesheets}" var="cssFile">
<link href="<cms:link>${cssFile}</cms:link>" rel="stylesheet" type="text/css">
</c:forEach>

<link href="<cms:link>../resources/css/style.css?preset=${cms.presetPath}&style=${cms.stylePath}</cms:link>" rel="stylesheet" type="text/css">
<!--[if lte IE 6]>
<link href="<cms:link>%(link.weak:/system/modules/com.bestsoft/resources/css/patch_ie.css:8ffaafcc-e131-11dc-bbcd-3bdd2ea0b1ac)</cms:link>" rel="stylesheet" type="text/css">
<![endif]-->

<!-- insert individual stylesheet -->
<c:set var="stylesheet"><cms:property name="stylesheet" file="search"/></c:set>
<c:if test="${!empty stylesheet}">
<link href="<cms:link>${stylesheet}</cms:link>" rel="stylesheet" type="text/css">
</c:if>

<cms:editable/>
</head>
主要是用CmsTemplateLayout类去读取样式表和基本框架的内容
第二步构件body区
1)头部导航区域
<div id="topnav">
<a href="#content" class="skip">Skip to Main Content</a>
<c:if test="${!cms.options.value['TopNav'].isEmptyOrWhitespaceOnly}">
<c:out value="${cms.options.value['TopNav']}" escapeXml="false" />
</c:if>
</div>
<c:if test="${!cms.options.value['Header'].isEmptyOrWhitespaceOnly}">
<c:out value="${cms.options.value['Header'].resolveMacros}" escapeXml="false" />
</c:if>
</div>
<!-- end: header -->

<!-- begin: main navigation -->
<c:choose>
<c:when test="${!empty cms.styleValue['nav.main']}">
<cms:include file="${cms.styleValue['nav.main']}"/>
</c:when>
<c:otherwise>
<!-- <cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/menu/nav_style2.jsp:ee5498d9-dbe4-11dc-b087-3bdd2ea0b1ac)"/> -->
</c:otherwise>
</c:choose>
<!-- end: main navigation -->

<!-- begin: breadcrumb -->
<div id="breadcrumb">
<cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/breadcrumb.jsp:e72c6f1c-dbb3-11dc-af66-3bdd2ea0b1ac)" />
</div>
<!-- end: breadcrumb -->
读区站点config文件中的option设置,主要内容有头部导航和头部图片和底部的logo;
用resources中的nav_style.jsp与breadstrumb.jsp去动态导航;
第三步构建左部区域
<div id="col1">
<div id="col1_content" class="clearfix">
<c:if test="${cms.presetValue['column.left.visible'] == 'true'}">
<!-- include the left navigation menu -->
<c:if test="${cms.presetValue['nav.left.visible'] == 'true'}">
<cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/menu/nav_left.jsp:ee1ea4f4-d97c-11dc-bc65-3bdd2ea0b1ac)" />
</c:if>

<!-- include the boxes on the left side -->
<cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/boxes.jsp:622548e8-d886-11dc-8ec1-3bdd2ea0b1ac)">
<cms:param name="orientation" value="left" />
<cms:param name="config" value="${cms.configPath}" />
</cms:include>
</c:if>
</div>
</div>
读取框架文件,由nav_left.jsp去动态创建左边的内容
第四步,构建右部区域
<div id="col3">
<div id="col3_content" class="clearfix">
<c:catch>
<c:set var="page" value="${cms:vfs(pageContext).readXml[cms:vfs(pageContext).context.uri]}" />
</c:catch>

<!-- include the boxes on the right side -->
<c:if test="${cms.presetValue['column.right.visible'] == 'true'}">
<cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/boxes.jsp:622548e8-d886-11dc-8ec1-3bdd2ea0b1ac)">
<cms:param name="orientation" value="right" />
<cms:param name="config" value="${cms.configPath}" />
</cms:include>
</c:if>
</div>
</div>
同样由preset指定,由boxes.jsp来创建内容
第五步,构建中间和底部区域
<div id="col2">
<div id="col2_content" class="clearfix">
<!-- anchor for accessible link to main content -->
<a id="content" name="content"></a>
</cms:template>
<cms:template element="body">
<cms:include element="body" editable="true"/>
</cms:template>
<cms:template element="foot">
<!-- include the second body from an xml page, if available -->
<c:if test="${page.hasValue['body2']}">
<cms:include element="body2" editable="true"/>
</c:if>
<!-- include the boxes in the center -->
<cms:include file="%(link.weak:/system/modules/com.bestsoft/elements/boxes.jsp:622548e8-d886-11dc-8ec1-3bdd2ea0b1ac)">
<cms:param name="orientation" value="center" />
<cms:param name="config" value="${cms.configPath}" />
</cms:include>
</div>
<div class="clear"> </div>
</div>
<!-- end: center column -->
</div>
<!-- end: content area -->

<!-- begin: #footer -->
<div id="footer">
<c:if test="${!cms.options.value['Footer'].isEmptyOrWhitespaceOnly}">
<c:out value="${cms.options.value['Footer'].resolveMacros}" escapeXml="false" />
</c:if>
</div>
<!-- end: #footer -->

</div>
中间是可编辑区域,最后读取option文件来配置底部框架
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值