天涯html&css基础框架

html申明

对ie6-8在html中添加no-css3这个class和各个版本的class,对ie7以下添加lte7这个class,然后根据我们目前使用浏览器的比例,把第一的ie6放在判断第一位。

<!DOCTYPE HTML>

<!--[if IE 6]><html class="ie6 lte9 lte7 no-css3" lang="zh-cn"><![endif]-->

<!--[if IE 8]><html class="ie8 lte9 no-css3" lang="zh-cn"><![endif]-->

<!--[if IE 9]><html class="ie9 lte9 no-css3" lang="zh-cn"><![endif]-->

<!--[if IE 7]><html class="ie7 lte9 lte7 no-css3" lang="zh-cn"><![endif]-->

<!--[if !(IE 6) | !(IE 7) | !(IE 8) | !(IE 9)  ]><!--><html lang="zh-cn"><!--<![endif]-->

<head>

<meta charset="UTF-8">

<title>无标题文档</title>

</head>



<body>



</body>

</html>

判断浏览器,添加所需文件

//为ie6-8添加一个ie.css文件

<!--[if lte IE 8]><link href="css/ie.css" type="text/css" rel="stylesheet" media="all"><![endif]-->

//为ie6添加处理png的js文件

<!--[if IE 6]>

      <script type="text/javascript" src="js/DD_belatedPNG_0.0.8a-min.js?_v=<%=JS_VERSION%>"></script>

      <script type="text/javascript">

          //给所有需要处理的png图片加上dd-pngifx这个class,就可以处理了

          DD_belatedPNG.fix(".dd-pngfix");

      </script>

<![endif]-->

常规布局

这个布局的特点是border,margin,padding由里面的inner部分来完成,所以左中右三个加起来就是总的宽度,而不用考虑左中右的margin,border,padding之类的,当然之所有选择这个布局,还有其他的一些变化,详细请参看布局。这里列出左右边栏布局的代码以供参考。

<div class="page asides-two">

    <div class="wrap-header">

        <div id="header">

            <div class="inner clearfix"></div>

        </div>

    </div><!--wrap-header-->

    <div class="wrap-container">

        <div id="container" class="clearfix">

            <div id="aside_left" class="aside">

                <div class="inner"></div>

            </div><!--aside_left-->



            <div id="main">

                <div class="inner clearfix"></div>

            </div><!--main-->



            <div id="aside_right" class="aside">

                <div class="inner"></div>

            </div><!--aside_right-->

        </div>

    </div><!--wrap-container-->

    <div class="wrap-footer">

        <div id="footer">

            <div class="inner clearfix"></div>

        </div>

    </div><!--wrap-footer-->

</div>

关于H1

在首页的时候,网站的h1标题为站点名字,当网站在内页的时候,内页标题为h1。所以对站点名字输出进行判断,以jsp为例:

<% if(isFront) { %>

  <h1 class="ele-invisible">天涯游戏</h1>

<% }else { %>

  <strong class="ele-invisible">天涯游戏</strong>

<% } %>

当然大多数时候其实我们一般是显示logo,而网站名称我们也许是需要隐藏的,那样我们添加了个ele-invisible的class,这个class的样式为:

/*ele-invisible  */

.ele-invisible{

    position: absolute;

    clip:rect(1px 1px 1px 1px);/* ie6,7*/

    clip: rect(1px, 1px, 1px, 1px);

}

边栏区块

边栏一般加有aside-block这个class,然后每个区块有一个属于自己的id,以方便协作查阅及日后修改。内容由block-content这个class包括起来,如果标题右侧有更多等信息,使用head-title结构。当然如果边栏区块足够简单如就一张图片,那就根本就不需要这个结构了。

<div id="" class="aside-block">

  <h2></h2>

  <div class="block-content"></div>

</div>



<!-- 标题右侧有更多等文字信息 -->

<div id="" class="aside-block">

  <div class="head-title clearfix">

    <h2></h2>

    <a href="#" class="more"></a>

  </div>

  <div class="block-content"></div>

</div>

tabs选项卡

对所有的选项卡提供一个相同的class结构以方便js操作,标题用tabs-nav包裹起来,tabs-content里面放切换的内容,所有的内容用tabs-content-wrap包裹。如果项目本来就一种tabs,那么可以直接在这三个class上面定义样式,如果有多种tabs样式,建议样式由其他class来控制。

<h2 class="tabs-nav"><a class="active" href="#">title1</a><a href="#">title2</a></h2>

<div class="tabs-content-wrap">

  <div class="tabs-content">content1</div>

  <div class="tabs-content">content2</div>

</div>

多列

这里的多列指的是二等分,三等分或四等分的情况,二等分的时候class为col-two,三等分的class为col-three,四等分的class为col-four,当然因为子元素并列排行所以一般也得配合clearfix用,然后子元素有一个共同的class为col。对于最后一栏margin的处理,可以采用加个class为last,或者使用父元素的负margin来撑大容器。

<!-- 两列 -->

<div class="col-two clearfix">

  <div class="col">

    <h2></h2>

    <div class="col-content"></div>

  </div>

  <div class="col">

    <h2></h2>

    <div class="col-content"></div>

  </div>

</div>



<!-- 三列 -->

<div class="col-three clearfix">

  <div class="col">

    <h2></h2>

    <div class="col-content"></div>

  </div>

  ...

</div>



<!-- 四列 -->

<div class="col-four clearfix">

  <div class="col">

    <h2></h2>

    <div class="col-content"></div>

  </div>

  ...

</div>

 

From: http://www.w3cplus.com/framework/index.php

你可能感兴趣的:(html)