小K的H5之旅-实战篇(一)

一、前言

本K在经过两个星期的html和css学习之后,第一次去尝试完成一个网站主页的制作。在四天之后,本K也终于完成了杰瑞教育主页的html和css部分,至于部分涉及js的部分,因为本K还没有学习过这一块,所以就先做了个样式(网页部分效果如下图)。在完成这一页面的时候,K又发现了许多我们还没有学到,但是在网页制作中经常会用到的一些属性,会遇到一些细节上的问题。因此,K写了这篇博文,来记录一下这些属性和问题。

 

 

二、属性记录

1、display

      display用来定义元素的框的类型,常用的有两个值:block(将元素框类型转为块级)和inline(将元素框类型转为行级)。在这次网站制作中,在使用频率上,K使用的前者居多,经常用在img和span标签上,尤其在需要两者浮动或单独占据一行时。(不要问我为啥不用p标签来取代span,仅仅是因为觉得p有点不太顺眼而已=。=)

2、position

      position用来对页面中元素进行定位,常用值有:relative(相对)和absolute(绝对)。在这次网页制作中,凡是float不能解决或者比较麻烦的细节上,K都是用的position来解决的。而且,position这个属性也会常用在网页的大图处理上,这一点会在第三部分详细阐述。另外,用position的时候,一定要注意周围元素的层次关系,否则会出现遮挡覆盖的问题。

      详解如下↓

    相对定位

    使用position:relative;设置元素为相对定位的元素

    定位机制:

      相对于自己原来的文档流中的位置进行定位,当不指定top等定位值时,不会改变元素位置

      相对定位元素仍会占据原有文档流中的位置,而不会释放

    使用left/right top/bottom调整位置,当前两者同时存在,left生效;后两者同时存在,top生效(不常用,常用来锁住绝对定位)

   绝对定位

   使用position:absolute;设置元素为绝对定位元素

   定位机制

      相对于第一个非static的祖先元素(使用了relative、absolute、fixed定位的祖先元素)进行定位

      如果所有均未定位,则相对于浏览器左上角进行定位

     使用absolute的元素,会从文档流中完全删除,原有空间释放不占有

   fixed

    position:fixed;是一种特殊的绝对定位父容器无法使用relative锁住

    定位机制:永远相对于浏览器进行定位

   Z-index

    作用:设置定位元素的z轴层叠顺序

    使用要求:

      必须是定位元素才能使用,absolute/relative/fixed 

      使用时需要考虑父容器的约束。

        如果父容器为z-index:auto; 则子容器额z-index可以不受父容器的约束;

        如果父容器进行了设置,则子容器的层叠将以父容器的为准(在同一容器中的不同子元素仍可以通过自己的z-index调整层叠关系)

     z-index:auto; 与 z-index:0; 的异同

       前者为默认值,与后者处于同一平面

       前者不会约束子元素的z-index层次;而后者会约束且与父元素处于同一平面 

     z-index相同(处于同一平面的定位元素)的层叠关系:后来者居上!

 

3、transform

      transform用来定义元素的2D、3D转换效果,在整个主页中算是比较常用的属性。具体常用属性值有缩放scale()和Y轴旋转rotateY(),其他的不做过多的叙述,就借鉴一下W3School(http://www.w3school.com.cn/cssref/pr_transform.asp)上的介绍吧。

4、transition

      transition用来定义转换的过渡效果,比如转换的时长一类的问题。

三、问题记录

1、CSS选择器权重计算问题

       行内(1000)>ID选择器(100)>class选择器(10)>标签选择器(1)

       举个栗子:#div .div .div1 .div2 div  的权重就等于100+10+10+10+1=131.

2、如何处理网页中1920大图的放置问题

举个栗子:

(html部分:原图经切割为4等分,插入方式为div背景图拼接)

<div id="adv">
    <div class="adv">
        <div class="one"></div>
        <div class="two"></div>
        <div class="three"></div>
        <div class="four"></div>
    </div>
</div>

(css部分)

#adv{
    width: 100%;
    height: 500px;
    position: relative;
    overflow: hidden;
}
#adv .adv{
    position: absolute;
    width:1920px ;
    height: 500px;
    left: 50%;
    margin-left: -960px;
}
#adv div{
    width: 480px;
    height: 500px;
    float: left;
    background-repeat: no-repeat;
    background-size: contain;
}
#adv .one{
    background-image: url(../img/abstract/20170121094034635.jpg);
}
#adv .two{
    background-image: url(../img/abstract/20170121094108366.jpg);
}
#adv .three{
    background-image: url(../img/abstract/20170121094154220.jpg);
}
#adv .four{
    background-image: url(../img/abstract/20170121094218539.jpg);
}

 (效果图如下 请主动忽视掉两侧的侧边栏=。=)

 

3、网页的三维结构问题

      网页是一个立体的结构,在三维空间上,除了我们所见到的x、y轴上的平面图像,还包括有在z轴上的所谓的元素间层次的问题。在大部分时候,我们经常会遇到在使用绝对定位时,让其周围元素被掩盖在绝对定位元素以下的问题,在这种时候,我们就可以利用在被掩盖元素的样式上添加z-index属性并赋值来将被掩盖的元素“浮”到上层来。当然,多个z-index存在时,是根据其赋值大小来决定层次,值越大,层次越向上。

4、其他问题

      4.1 在网页制作时,会发现整个页面与浏览器边之间存在一定的边距,这种时候我是通过在全局上设置margin和padding为0来解决的。

      4.2 在使用ul或者ol或者dl时,去除子项前的标志后,ul/ol/dl会默认自己存在一层边距,此时也是利用margin和padding为0来解决的。

      4.3 在网页制作时,div是一个非常常用且好用的标签。

四、后记

      网页制作真的是一个非常活泼的东西。以前在练习独立的板块时,K觉得网页制作是一件很枯燥乏味的事情。但当K真正制作一个完整网页的时候,在整体把控、页面布局、细节处理、还有为元素添加各种样式之后,整个页面所呈现的活泼的感觉,以及完成一个页面的成就感和满足感让K觉得网页制作,或者说未来K要接触的整个前端工程会是一个很跳跃、很活泼的工作。

posted on 2017-03-11 13:10  谁还在我身边  阅读(446)  评论(0编辑  收藏  举报

导航