转自:http://www.mamicode.com/info-detail-503562.htmlcss
Bootstrap是一个响应式的布局,你能够在宽屏电脑、普通电脑,平板电脑,手机上都获得很是优秀的布局体验。这种响应式的布局正是经过CSS3的媒体查询(Media Query)功能实现的,根据不一样的分辨率来匹配不一样的样式。IE8浏览器并不支持这一优秀的Css3特性,Bootstrap在开发文档中写了如何使用进行兼容IE8。可是笔者屡次尝试没有成功,IE8的布局是乱的。直到今天忍无可忍,决定再尝试一下,最终得到成功。有些细节没有注意到,致使IE8无法响应式布局。html
下面讲解下如何让Bootstrap 3兼容IE8浏览器,至于有人会问我如何兼容IE6 IE7,请绕道搜索bsie (bootstrap2)。前端
Bootstrap在IE8中确定不如Chrome、Firefox、IE11那么完美,部分组件不保证彻底兼容,仍是要Hack的。这里不谈。html5
使用zencoding的用户 输入 html:5 再按Tab键便可。jquery
前者定义媒体查询,后者肯定显示此网页的IE版本。git
这步十分重要,这里要看你是引用其余网站(CDN)的bootstrap文件仍是把Bootstrap文件放本地。
这里我放在本地,由于以后的部署比较简单。github
respond.js(Github)是用于媒体查询的,项目说明描述:要和须要进行媒体查询的文件放在同一域中。否则CDN部署的须要更改一些选项,以后再说。ajax
html5shiv : html5.js(Google Code)(Github)是让不(彻底)支持html5的浏览器“支持”html5标签。bootstrap
详情请见:https://github.com/scottjehl/Respond#cdnx-domain-setup浏览器
Github上说,这个js是经过ajax复制一份你的css文件。因此须要一个代理页面去请求文件。
须要上传一些文件,步骤比较复杂,并且通常公共CDN基本没人有这种操做权限。
以后再添加代码。
Jquery 2.0以上就再也不支持IE 6/7/8 这三大虐心神器了。因此要想使用Bootstrap3中的一些插件效果,好比modal 弹出层对话框这类控件。咱们就须要添加 2.0如下的,这里我用1.10.2的Jquery库。
本人非前端工程师,只是爱好者一枚,若有错误还请批评指教。你们相互学习~
本人也正是作了个Bootstrap3的小项目(姓名代码查询),正是这个项目让我总结以上经验出来。
主要仍是在于让respond.js起效果,关键就是让bootstrap的文件和respond.js同域,不一样域须要用CDN上的html作ajax。
懒人代码总结以下:
<!doctype html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="author" content="Jophy" />//可删 <title>ie8</title> <link rel="stylesheet" href="bootstrap/css/bootstrap.min.css"> <link rel="stylesheet" href="bootstrap/css/style.css">//根据须要引用 <!--[if lte IE 9]> <script src="bootstrap/js/respond.min.js"></script> <script src="bootstrap/js/html5.js"></script>//根据须要引用(本此项目未引用) <![endif]--> <script src="http://libs.baidu.com/jquery/1.10.2/jquery.js"></script>//根据须要引用 <script src="bootstrap/js/bootstrap.min.js"></script> </head>//根据须要引用 <body> </body> </html>