项目需求

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. HDU-3746-Cyclic Nacklace(KMP,循环节)

    Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...

  2. mysql查询表中最小可用id值

    今天在看实验室的项目时,碰到的一个问题,.先把sql语句扔出来 // 这条语句在id没有1时,不能得到正确的查询结果. select min(id+1) from oslist c where not ...

  3. JS中的方法运用笔记

    1.警告(alert 消息对话框) alert(字符串或变量); <script type="text/javascript"> var mynum = 30; ale ...

  4. 条款33:避免遮掩继承而来的名称(Avoiding hiding inherited names)

    NOTE: 1.derived classes 内的名称会遮掩base classes内的名称.在public继承下从来没有人希望如此. 2.为了让被遮掩的名称再见天日,可使用using 声明方式或转 ...

  5. ubuntu 宝塔安装一条龙服务

    ubuntu 安装 1, wget -O install.sh http://download.bt.cn/install/install-ubuntu.sh && sudo bash ...

  6. TeeChart Pro VCL/FMX教程之使用函数

    函数类型 函数特点 TeeChart Pro功能是一个系列,几乎可以是任何系列类型,应用代数函数,数据源是另一个图表系列. 所有函数都派生自TTeeFunction组件并继承TeeFunction的P ...

  7. PHPTaint-检测xss/sqli/shell注入的php扩展模块[转]

    web渗透者习惯采用黑盒或灰盒的方面来检测一款web应用是否存在漏洞,这种检测方法可以屏蔽不少漏洞,特别是程序逻辑中的漏洞.但如果能配合白盒的源码审计(也可以叫漏洞挖掘),效果将会更好,当然人力成本也 ...

  8. Python 迭代器&生成器,装饰器,递归,算法基础:二分查找、二维数组转换,正则表达式,作业:计算器开发

    本节大纲 迭代器&生成器 装饰器  基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...

  9. HDU1412-{A} + {B},通过率并不高,但同样是用一个很简洁的函数unique,超短代码水过~

    {A} + {B} Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) http: ...

  10. Maven的scope依赖作用域说明

    Maven的scope依赖作用域说明 1.test范围指的是测试范围有效,在编译和打包时都不会使用这个依赖 2.compile范围指的是编译范围有效,在编译和打包时都会将依赖存储进去 3.provid ...