Bootstrap是一组用于网站和网络应用程序开发的开源前端(所谓“前端”,指的是展现给最终用户的界面。与之对应的“后端”是在服务器上面运行的代码)框架,包括HTML、CSS及JavaScript的框架,提供字体排印、窗体、按钮、导航及其他各种组件及Javascript扩展,旨在使动态网页和Web应用的开发更加容易。
网络上有很多关于 bootstrap 的学习资源,如果你还没有听说过这个优秀的小东西,那么我们建议你用一天的时间对它进行了解和学习,学习过后,相信你会感觉自己一天的付出是相当值得的。
# 引入bootstrap
我们知道,bootstrap的原则是:先行后列再内容,或是先行后列再行再列再内容。
>行套列,列套内容。行里面永远是列,列里面可以是内容也可以是行。
下载bootstrap的min.css文件,下载地址为:http://www.bootcss.com/
你也可以去bootstrap中文站上去下载和学习: http://v3.bootcss.com/
下载后把min.css文件放置到static文件夹中,具体路径如下图所示:
![](https://box.kancloud.cn/2016-06-13_575e70e54b376.png)
我们在git仓库中,为大家准备好了全部文件,你只需要执行。
~~~
git checkout -f step3.2.6
~~~
便可以在代码仓库中的public文件下找到所需要的bootstrap文件,然后把它们复制到thinkphp5文件夹中对应的位置上就好了。
![](https://box.kancloud.cn/2016-06-29_577350f7160fc.png)
D:\xampp\htdocs\thinkphp5guide\public\static目录中的bootstrap-3.3.5-dist文件夹,里面也包含min.css文件,如下所示:
![](https://box.kancloud.cn/2016-06-29_577350f73871d.png)
## 绝对地址与相对地址
我们在以往开发网站的时候,更多的是采用相对地址,这样更便于我们进行项目的迁移。但在实际的项目中,由于URL默认值的原因,直接引用相对地址会存在一定的问题。
比如我们引用一张图片,引用的代码往往习惯于这样写:
~~~
<img src="image/1.jpg" />
~~~
这样写的好处显而易见:当我们进行html代码的迁移时,不需要更改任何图片的路径便可以完美显示 。
但在ThinkPHP中,这却给我们带来了挑战。我们在学习MCA时,接触了ThinkPHP的默认值。即:http://127.0.0.1/thinkphp5/public/index/Teacher 与 http://127.0.0.1/thinkphp5/public/index/Teacher/index 触发的是相同的触发器,实现的也是相同的功能。如果此时,我们把上面的图片代码放置于相应的V层中,就会出现以下问题:
当URL为[http://127.0.0.1/thinkphp5/public/index/Teacher](http://127.0.0.1/thinkphp5/public/index/Teacher)时,这个图片应该放置于`public/index/`下。
而当URL为[http://127.0.0.1/thinkphp5/public/index/Teacher/index](http://127.0.0.1/thinkphp5/public/index/Teacher/index)时,却又要放置到`public/index/Teacher`下。
天,怎么会这样?到底我们是该放在`public/index/`下还是放在`public/index/Teacher`下呢?
很明显,我们没有办法保障在每个对应的目录下,都放上一张相同的图片。
其根本问题在于,由于URL默认值的存在,我们控制不了用户访问哪个URL,当然也就弄不清楚到底应该相对于哪个路径放置图片了。
有点难懂是吧,没关系,看一下就好了,我们会用一种动态的路径生成方法来解决这个问题,只需简单知道一些原因就可以了。
在这里,我们暂时使用绝对路径来解决这个问题。
【相对】:是指相对于用户访问的当前文件。
【绝对】:是指相对于htdocs这个文件夹。
> 相对路径与绝对路径比较模糊的话,`google`一下吧。
在这强调一下,如果我们搜索与技术相关的内容,用google会使你的效率事半功倍。
>如何使用google http://ihavenolimitations.xyz/yunzhiclub/google
## 引入bootstrap
引用bootstrap.min.css样式的代码如下:
~~~
<head>
<meta charset="UTF-8">
<title>教师管理</title>
<link rel="stylesheet" type="text/css" href="/thinkphp5/public/static/bootstrap-3.3.5-dist/css/bootstrap.min.css">
</head>
<body>
~~~
### 测试
打开浏览器的控制台,并刷新访问页面。
chrome:
![](https://box.kancloud.cn/2016-06-13_575e70e572ace.png)
firefox:
![](https://box.kancloud.cn/2016-06-24_576cd5bce06c9.png)
当我们看到这个文件的类型值stylesheet不是红色字体时,说明我们已经成功引入了Boostrap。
错误引入时显示结果如下图所示:
![](https://box.kancloud.cn/2016-06-13_575e70e597c6c.png)
当然了,最安全的方法是点击这个文件名,然后看一下响应那里到底显示的是什么信息。如下图所示:
![](https://box.kancloud.cn/2016-06-13_575e70e5ace21.png)
如果看到上图显示结果,证明我们成功引入了boostrap样式文件。
其实最简单的变化是观察刷新前后的字体变化,引用成功后,字体样式会变得更美观一些。
- 序言
- 第一章 准备知识
- 第一节:XAMPP
- 第二节:NAVICAT
- 第三节:GIT
- 第二章 HelloWorld
- 第一节:下载THINPHP5.0
- 第二节:启动xampp
- 第三节:hello thinkphp
- 第四节:Hello world
- 第五节:MCA
- 第六节:单引号与双引号
- 第三章 教师管理
- 第一节:新建数据库
- 第二节:CURD之R 读数据
- 3.2.1 时序图
- 3.2.2 连接数据库
- 3.2.3 直接读取数据
- 3.2.4 间接读取数据
- 3.2.5 使用V层显示数据
- 3.2.6 引入bootstrap
- 3.2.7 加入bootstrap样式
- 第三节:CURD之 C 增加数据
- 3.3.1 插入数据
- 3.3.2 表单传值
- 3.3.3 存储表单数据
- 3.3.4 自动时间戳
- 3.3.5 增加验证
- 第四节:CURD之 D 删除数据
- 3.4.1 什么是关键字
- 3.4.2 删除数据
- 3.4.3 定制删除链接
- 3.4.4 完善删除
- 第五节:CURD之 U 更新数据
- 3.5.1 读取数据
- 3.5.2 展示数据
- 3.5.3 修改数据
- 3.5.4 传递数据
- 3.5.5 接收数据
- 3.5.6 更新数据 方法一
- 3.5.7 更新数据 方法二
- 第六节:衔接各个action & 重构代码
- 3.6.1 index action
- 3.6.2 add action
- 3.6.3 insert action
- 3.6.4 delete action
- 3.6.5 edit action
- 3.6.6 update action
- 第七节:分页
- 3.7.1 调用内置分页
- 3.7.2 select与paginate(选学)
- 3.7.3 分页原理(选学)
- 3.7.4 调用page(选学)
- 第八节:模糊查询
- 3.8.1 增加查询
- 3.8.2 完善查询
- 第四章 登录与注销
- 第一节:cookie 与 session
- 第二节:静态方法
- 第三节:规划URL跳转
- 第四节:登录
- 4.4.1 登录流程
- 4.4.2 index action
- 4.4.3 login action
- 4.4.4 引入M层
- 4.4.5 异常Exception
- 第五节:注销
- 第六节:验证
- 4.6.1 action增加验证
- 4.6.2 使用构造函数验证
- 4.6.3 使用继承验证
- 第五章 E-R图与数据字典
- 第一节:第一张E-R图
- 第二节:实体间的关系
- 第三节:开发规范
- 第六章 班级管理
- 第一节:建立数据表
- 第二节:数据列表index
- 第三节:增加数据add
- 第四节:编辑数据edit
- 第五节:删除数据delete
- 第七章 学生管理
- 第一节:建立数据表
- 第二节:数据列表
- 7.2.1 显示性别
- 7.2.2 显示创建时间
- 7.2.3 显示班级名称
- 7.2.4 显示辅导员姓名
- 第三节:编辑数据
- 第四节:魔法函数
- 第五节:源码分析
- 第八章 课程管理
- 第一节:建立数据表
- 第二节:新增课程
- 第三节:编辑课程
- 8.3.1 edit
- 8.3.2 update
- 第九章 代码重构
- 第一节:add 与 edit
- 第二节:insert 与 update
- 第三节:模板继承
- 9.3.1 index.html
- 9.3.2 edit.html
- 9.3.3 小结
- 第十章 UML图
- 第一节:E-R图回顾
- 第二节:UML图
- 第十一章 菜单与路由
- 第一节:添加菜单
- 第二节:虚拟主机
- 第三节:定制路由
- 第十二章 开发调试
- 第一节:开启trace
- 第二节:查看日志
- 第十三章:总结