项目需求

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

要求制作上图所看到的的效果,能达到灵活可配的效果。

我想初步想法是用div+css来制作。

------------------------------------------------------------------------------------------------------

模型抽象

以下的这个模型是我抽象出来的一个简单的解决方式。div能够表示一个矩形。然后再加上一个旋转90度的div就能够组起来达到我们想要的效果了。使用div就能够非常方便地对应各种事件。使站点灵活可配。

------------------------------------------------------------------------------------------------------

技术难点

1、怎样做到让div旋转?

-moz-transform: rotate(90deg);

假设设置的值为正数表示顺时针旋转,假设设置的值为负数,则表示逆时针旋转

2、怎样设置div的层次关系?

z-index

------------------------------------------------------------------------------------------------------

实践过程

HTML页:

-------------------------------------------------------------------------

<html>

    <head>

        <title>test</title>

        <link rel="stylesheet" type="text/css" href="css/chainselect.css">

        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

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

    </head>

    

    <body>

        <div id="rectangle1" onmousemove="MouseMove(this)">新生报到流程</div>

        <div id="arrow1" onmousemove="MouseMove(this)"></div>

        

        <div id="arrow21"></div>

        <div id="rectangle2">公约页</div>

        <div id="arrow22"></div>

        

        <div id="arrow31"></div>

        <div id="rectangle3">完好个人信息</div>

        <div id="arrow32"></div>

        

        <div id="arrow41"></div>

        <div id="rectangle4">选择缴费方式</div>

        <div id="arrow42"></div>

        

        <div id="arrow51">sss</div>

        <div id="rectangle5">新生报到流程</div>

    </html>

-------------------------------------------------------------------------

CSS页

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------

#rectangle1 {

  border:2px solid;

  border-right:none;

  background-color:#34B0D9;

  width:169px;

  height:29px;

  float:left;

  text-align:center;

  font-size:16px;

  padding-top:5px;

  }

#arrow1 {

  float:left;

  -moz-transform: rotate(45deg);

  border:2px solid;

  background-color:#34B0D9;

  width:25px;

  height:25px;

  position:relative;

  top:5px;

  left:-14px;

  border-bottom:none;

  border-left:none;

 

}

#arrow21{

    float:left;

    -moz-transform: rotate(45deg);

    border:2px solid;

    background-color:#FFFFFF;

    height:32px;

    width:32px;

  position:relative;

  left:-35px;

  top:5px;

  z-index:-1;

    border:none;

}  

#rectangle2 {

  border:2px solid;

  border-right:none;

  background-color:#34B0D9;

  width:169px;

  height:29px;

  float:left;

  text-align:center;

  font-size:16px;

  padding-top:5px;

  float:left;

  position:relative;

  left:-50px;

  z-index:-2;

  border-left:none;

  }

  #arrow22 {

  float:left;

  -moz-transform: rotate(45deg);

  border:2px solid;

  background-color:#34B0D9;

  width:25px;

  height:25px;

  position:relative;

  top:5px;

  left:-63px;

  border-bottom:none;

  border-left:none;

}

#arrow31{

    float:left;

    -moz-transform: rotate(45deg);

    border:2px solid;

    background-color:#FFFFFF;

    height:32px;

    width:32px;

  position:relative;

  left:-84px;

  top:5px;

  z-index:-1;

    border:none;

}  

#rectangle3 {

  border:2px solid;

  border-right:none;

  background-color:#34B0D9;

  width:169px;

  height:29px;

  float:left;

  text-align:center;

  font-size:16px;

  padding-top:5px;

  float:left;

  position:relative;

  left:-100px;

  z-index:-2;

  border-left:none;

  }

    #arrow32 {

  float:left;

  -moz-transform: rotate(45deg);

  border:2px solid;

  background-color:#34B0D9;

  width:25px;

  height:25px;

  position:relative;

  top:5px;

  left:-113px;

  border-bottom:none;

  border-left:none;

}



#arrow41{

    float:left;

    -moz-transform: rotate(45deg);

    border:2px solid;

    background-color:#FFFFFF;

    height:32px;

    width:32px;

  position:relative;

  left:-134px;

  top:5px;

  z-index:-1;

    border:none;

}  

#rectangle4 {

  border:2px solid;

  border-right:none;

  background-color:#34B0D9;

  width:169px;

  height:29px;

  float:left;

  text-align:center;

  font-size:16px;

  padding-top:5px;

  float:left;

  position:relative;

  left:-148px;

  z-index:-2;

  border-left:none;

  }

    #arrow42 {

  float:left;

  -moz-transform: rotate(45deg);

  border:2px solid;

  background-color:#34B0D9;

  width:25px;

  height:25px;

  position:relative;

  top:5px;

  left:-161px;

  border-bottom:none;

  border-left:none;

}





#arrow51{

    float:left;

    -moz-transform: rotate(45deg);

    border:2px solid;

    background-color:#FFFFFF;

    height:32px;

    width:32px;

  position:relative;

  left:-180px;

  top:5px;

  z-index:-1;

    border:none;

}  

#rectangle5 {

  border:2px solid;

  background-color:#34B0D9;

  width:169px;

  height:29px;

  float:left;

  text-align:center;

  font-size:16px;

  padding-top:5px;

  float:left;

  position:relative;

  left:-196px;

  z-index:-2;

  border-left:none;

  }

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------

---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

实践效果

总结思考

1、面对复杂的问题。要学会抽象当前的问题。

2、不将就是发现的原动力。

项目实战之玩转div+css制作自己定义形状的更多相关文章

  1. 利用DIV+CSS制作网页过程中常用的基本概念及标签使

    CSS主要用于对HTML文件功能的补充及扩展,其作用就是对HTML文件中各种排版进行设置,达到对网页中字体.颜色.背景.图片等的控制,使网页能够完全依照设计者的想法来显示. CSS可以控制网页的显示, ...

  2. 利用DIV+CSS制作网页过程中常用的基本概念及标签使用细节

    CSS主要用于对HTML文件功能的补充及扩展,其作用就是对HTML文件中各种排版进行设置,达到对网页中字体.颜色.背景.图片等的控制,使网页能够完全依照设计者的想法来显示. CSS可以控制网页的显示, ...

  3. Div+Css制作圆

    Div+Css制作四分之一圆主要是使用Css3.0中的border-radius这个圆角隐藏属性.利用这一属性,我们可以画圆,画半圆,四分之三圆,四分之一圆等.以后我会更新…… 如何使用border- ...

  4. DIV+CSS制作二级横向弹出菜单,略简单

    没有使用JavaScript控制二级菜单的显示,结果如上图所示. 代码如下: <!DOCTYPE html> <html> <head> <meta char ...

  5. 纯Div+Css制作的漂亮点击按钮和关闭按钮

    纯Div+Css制作的漂亮点击按钮和关闭按钮,单击点击按钮也有效果.这些都不是图片.

  6. 使用div+css制作简单导航 以及要注意问题

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. DIV+CSS制作斜线效果记录

    DIV+CSS 斜线效果很简单,只需设置一下CSS Border 的边框就能有斜线效果.代码分享给大家,你可以自己变通. 提示要注意两点:1.DIV宽高的定义.2.DIV在 IE6 中默认是有高度的. ...

  8. div+css 制作表格

    <div class="table"> <h2 class="table-caption">花名册:</h2> <di ...

  9. div+css制作表格

    html: <div class="table"> <h2 class="table-caption">花名册:</h2> ...

随机推荐

  1. http请求响应格式

    当浏览器向Web服务器发出请求时,它向服务器传递了一个数据块,也就是请求信息,HTTP请求信息由3部分组成:l   请求方法URI协议/版本l   请求头(Request Header)l   请求正 ...

  2. python中的参数、全局变量及局部变量

    1.位置参数.关键字参数.默认参数的使用 位置参数.关键字参数 def test(x,y,z): print(x) print(y) print(z) test(1,2,3) #位置参数,必须一一对应 ...

  3. PHP 配置文件php.ini文件优化

    PHP 5.3.3 safe_mode = On #控制php中的函数执行比如system() 这个函数可以调用系统目录 比如 rm ,打开这个配置之后,同时把很多文件操作的函数进行了权限控制 saf ...

  4. POJ 1201 Intervals(差分约束 区间约束模版)

    关于差分约束详情可阅读:http://www.cppblog.com/menjitianya/archive/2015/11/19/212292.html 题意: 给定n个区间[L,R], 每个区间至 ...

  5. Android开发——查询/杀死手机里正在运行的进程

    0. 前言 以前有同学好像做过一个叫"自习君"的App,开启后自动检测用户这一天的自习时间,在学校里宣传广告还打了不少.其实实现原理非常简单,在SQlite数据库(也可以通过文件) ...

  6. Golang 编写 Tcp 服务器

    Golang 作为广泛用于服务端和云计算领域的编程语言,tcp socket 是其中至关重要的功能.无论是 WEB 服务器还是各类中间件都离不开 tcp socket 的支持. Echo 服务器 拆包 ...

  7. PS学习笔记(02)

    书籍推荐: <设计之下>这本APP设计书字里行间都透露出了真实,作者能将其工作流程和方法分享出来,实在值得尊敬.通过这本书全面了解了真实的设计工作是怎么做的,今后可以用到自己的工作中.赞! ...

  8. 74. Spring Data JPA方法定义规范【从零开始学Spring Boot】

    [从零开始学习Spirng Boot-常见异常汇总] 事情的起因:有人问过我们这个这个问题:为什么我利用Spring data jpa写的方法没有按照我想要的情况进行执行呢?我记得当时只是告诉他你你先 ...

  9. C# CreateDataTable

    public DataTable CreateDataTable()         {             DataTable dataTable = new DataTable();      ...

  10. python学习笔记--python数据类型

    一.整形和浮点型 整形也就是整数类型(int)的,在python3中都是int类型,没有什么long类型的,比如说存年龄.工资.成绩等等这样的数据就可以用int类型,有正整数.负整数和0,浮点型的也就 ...