发布于 2016-08-21 06:39:21 | 268 次阅读 | 评论: 0 | 来源: 网友投递
这里有新鲜出炉的Bootstrap v3教程,程序狗速度看过来!
Bootstrap Web前端CSS框架
Bootstrap是Twitter推出的一个开源的用于前端开发的工具包。它由Twitter的设计师Mark Otto和Jacob Thornton合作开发,是一个CSS/HTML框架。Bootstrap提供了优雅的HTML和CSS规范,它即是由动态CSS语言Less写成。Bootstrap一经推出后颇受欢迎,一直是GitHub上的热门开源项目,包括NASA的MSNBC(微软全国广播公司)的Breaking News都使用了该项目。
这篇文章主要介绍了Bootstrap编写一个在当前网页弹出可关闭的对话框,不用跳转,非弹窗,感兴趣的小伙伴们可以参考一下
使用弹窗在网页中显示短信息还行,虽然不那么地友好。然而,弹窗对于如同网站服务条款的长信息就无能为力的了。这是需要使用一个叫模态框modal的东西,并且在模态框里面嵌入一个多行文本框textarea。
这个东西,如果要手工写JavaScript代码就太难做了,但是使用Bootstrap来编写就简单起来。
一、基本目标
有一个网页,网页上面有一个超级链接,一个按钮:
点击他们都会打开一个如下所示的模态框,这个模态框,点击右上角的X按钮与下方的确定都会关闭。
二、制作过程
1.因为需要使用Bootstrap,所以先在官网下载组件即可,用于生产环境的Bootstrap版本,Bootstrap3对2并不兼容,建议直接根据其开发文档使用Bootstrap3。本文也是根据Bootstrap3制作。同时,Bootstrap3所提供的JavaScript效果需要到jQuery1.11支持,可以到jQuery官网中下载兼容旧浏览器IE6的jQuery1.11,而不是不兼容旧浏览器IE6的jQuery2。下载完之后,配置好站点目录。把Bootstrap3直接解压到站点目录,而把jquery-1.11.1.js放到js目录,也就是与bootstrap.js同一目录,站点文件夹的结构大致如下:
2.本网页编码如下,下面一个片段一个片段进行分析:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>模态框</title>
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no">
<link href="css/bootstrap.css" rel="stylesheet" media="screen">
<script type="text/javascript" src="js/jquery-1.11.1.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
</head>
<body>
<p>
<a data-toggle="modal" data-target="#myModal">服务协议</a>
</p>
<p>
<button type="button" class="btn btn-danger" data-toggle="modal"
data-target="#myModal">
点击此阅读服务协议
</button>
</p>
<div class="modal fade" id="myModal" role="dialog">
<div class="modal-dialog">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal">
<span>×</span>
</button>
<h4 class="modal-title" id="myModalLabel">
服务协议
</h4>
</div>
<div class="modal-body">
<p align="center">
<textarea class="form-control" rows=3 readonly="true" />
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
</textarea>
</p>
</div>
<div class="modal-footer">
<p align="center">
<button type="button" class="btn btn-default"
data-dismiss="modal">
确定
</button>
</p>
</div>
</div>
</div>
</div>
</body>
</html>
(1)<head>部分
<head>
<!--页面编码-->
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>模态框</title>
<!--要求本网页自动适应PC、平板、手机等设备的屏幕-->
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no">
<!--本例需要三个外部插件所支持-->
<link href="css/bootstrap.css" rel="stylesheet" media="screen">
<script type="text/javascript" src="js/jquery-1.11.1.js"></script>
<script type="text/javascript" src="js/bootstrap.js"></script>
</head>
(2)最初在网页所呈现的链接与按钮
<p>
<!--data-toggle="modal" data-target="#myModal"要求打开的myModal的模态框-->
<a data-toggle="modal" data-target="#myModal">服务协议</a>
</p>
<p>
<!--class="btn btn-danger"是按钮在Bootstrap的样式。-->
<button type="button" class="btn btn-danger" data-toggle="modal"
data-target="#myModal">
点击此阅读服务协议
</button>
</p>
(3)模态框部分
模态框的基本如下:
因此也就有了如下代码:
<!--class="modal fade"是要求模态框以动画效果fade打开,class="modal"也行,但打开得十分唐突。id="myModal"与上面的超级链接、按钮相呼应-->
<div class="modal fade" id="myModal" role="dialog">
<div class="modal-dialog">
<!--必须在modal-content之后才能进行模态框的布局。-->
<div class="modal-content">
<div class="modal-header">
<!--这是模态框的标题部分, ×加分号 为×的转移字符,实质是一个关闭按钮-->
<button type="button" class="close" data-dismiss="modal">
<span>×</span>
</button>
<!--这是模态框的标题-->
<h4 class="modal-title" id="myModalLabel">
服务协议
</h4>
</div>
<div class="modal-body">
<!--这是模态框的主体部分,内嵌一个行数为3的只读文本框,文本框在模态框主体部分居中,不用文本框也可以,但内容会一次性呈现给用户,那还不如直接弹窗算了?-->
<p align="center">
<textarea class="form-control" rows=3 readonly="true" />
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
本协议服务条款具有法律效力。
</textarea>
</p>
</div>
<div class="modal-footer">
<!--这是模态框的尾部,就放一个居中的确定按钮-->
<p align="center">
<button type="button" class="btn btn-default"
data-dismiss="modal">
确定
</button>
</p>
</div>
</div>
</div>
</div>