需求是这样的:

一个登录界面,让一张背景图片充满整个页面.需求看似非常简单,可是测试人员提的一个bug引起了我深入的思考.先上图,正常界面是这样的:

界面结构很简单,一个登录框,加一张背景图.我们都知道,使背景图片充满元素,只需添加如图所示的cover属性.

1.发现问题:

由于需要解决不同尺寸屏幕带来的布局问题,我尝试了各种方法.

最方便的,是把px替换成rem,可以解决大部分的此类问题.可惜只支持IE11及以上,故此适合于浏览器较新的移动端.

使用帮你解决了此类问题的UI插件?实际项目中,需要定制开发相应的样式,如果修改插件样式,成本很高,行不通.

于是,使用百分比.随之而来的问题是,当用户把浏览器缩小至窗口化,内部百分比元素全乱.

于是又寻找解决方案,去其他大型网站观察,比如搜狐,新浪...发现他们的网站,无论如何缩放,布局都不会乱,甚至丝毫不变,只是会多出滚动条.查看源码,有一个叫min-width和min-height的CSS属性,用于项目中,发现确实可以解决该问题.

但随之而来的,是另一个更奇怪的问题,如图:

浏览器全屏时,一切正常.但是当窗口化浏览器时,就会出现上图状况:

由于窗口宽度小于min-width,所以出现滚动条,不滚动的时候背景图正常,但滚动到右边,发现背景图神奇的只出现在左上角,占满未滚动前的部分,其他部分变成空白.也就是说,cover覆盖属性,在出现min-width带来的滚动条时失效了.

2.思考问题:

试了多种浏览器,都出现以上情况,排除了浏览器差异带来的影响.实际上,开发过程中,我们一般是不会随便去窗口化浏览器的.如果不是测试在bug平台上提交了这个bug,我也不会发现.

又试了不同尺寸分辨率的屏幕,问题是同样的.排除了尺寸差异的影响.也就是说,图片的cover属性在浏览器最大化状态是正常的,但是窗口化后,会出现一些问题,我相信这是浏览器自身的原因,而不是开发者的问题.

这是个不大不小的问题,因为它并不影响整体业务,可是,影响到了所谓的用户体验.用产品经理的话来说就是,你这样做,网站看起来就是山寨的.

3.解决问题:

问题的定义和原因都找到之后,就可以开始着手解决问题了.

首先,我取消了min-width和min-height属性,但是,登录框由于是百分比布局,会被压扁,导致布局错乱.

于是,我把这两个属性加在了登录框上.

终于,世界清静了.bug得到解决,一切回归正常.

网页占满整个屏幕_CSS网页背景图片等比例占满整个页面的解决方案相关推荐

  1. CSS网页背景图片等比例占满整个页面的解决方案

    需求是这样的: 一个登录界面,让一张背景图片充满整个页面.需求看似非常简单,可是测试人员提的一个bug引起了我深入的思考.先上图,正常界面是这样的: 界面结构很简单,一个登录框,加一张背景图.我们都知 ...

  2. css设置背景图片等比例铺满整个页面

    有次UI给我提出了bug说我的登录页的背景图变形了,后来查了下正确的背景图设置,如下: .login-box {width: 100%;height: 100%;background: url(&qu ...

  3. CSS背景图片平铺占满整个浏览器,且固定住不随滚动条移动

    背景图片平铺占满整个浏览器,且固定住不随滚动条移动的样式写法 body {background-image: url(../images/bakimg.jpg); background-size: 1 ...

  4. CSS:实现background-image背景图片全屏铺满自适应

    body {/* 加载背景图 */background-image: url(images/bg.jpg);/* 背景图垂直.水平均居中 */background-position: center c ...

  5. html添加背景图片并且填满div,css background-size与背景图片填满div(示例代码)

    background-size与背景图片填满div 在开发中,常有需要将一张图片作为一个div的背景图片充满div的需求 background-size的取值及解释 background-size共有 ...

  6. 【UGUI】 全屏背景图片等比例拉伸自适应

    效果如下: 首先感叹一下,UGUI的自适应做的还是非常不错的,RectTransform中提供了非常多种的自适应方式.对做界面来说还是很友好的. 如果界面上需要有个全屏的背景图(UI界面一般都是有的吧 ...

  7. vue.js 获取当前屏幕的宽度_vue 获取当前屏幕的宽度,图片等比例缩放,动态设置css样式...

    vue 获取当前屏幕的宽度,图片等比例缩放 这个是一个背景图,点击对应的圆圈就会出现一个蒙层上面显示详情,但是只要当前窗口大小变化了,因为我的蒙层大小是固定的px,所以不会变,就不在图片对应的位置了 ...

  8. 3种CSS实现背景图片全屏铺满自适应的方式

    来源 | https://www.fly63.com/ 一张清晰漂亮的背景图片能给网页加分不少,设计师也经常会给页面的背景使用大图,我们既不想图片因为不同分辨率图片变形,也不希望当在大屏的情况下,背景 ...

  9. html背景图片不重叠铺满,css背景图片怎么铺满

    该方法适用于所有品牌的电脑. CSS设置拉伸背景图片铺满屏幕 新建一个html文件,命名为test.html,用于讲解CSS中如何设置拉伸背景图片铺满屏幕. 在test.html文件内,使用div标签 ...

最新文章

  1. Linux下的QQ截图
  2. 使用CAShapeLayer实现一个音量大小动态改变的控件
  3. zabbix监控规划及实施
  4. jquery weui 中alert弹出框在ios中跳动问题
  5. 检验例题_高考必考|化学工艺流程之物质的分离提纯及检验鉴别,轻松拿分
  6. Contest2162 - 2019-3-28 高一noip基础知识点 测试5 题解版
  7. 百度前端学院参考答案:第二十五天到第二十七天 倒数开始 滴答滴 滴答滴(2)...
  8. L3-019 代码排版 (30 分)-PAT 团体程序设计天梯赛 GPLT
  9. 成功的软件系统=成熟产品+全面配置+专业定制
  10. Android电池驱动【转】
  11. MySQL用C访问的示例代码
  12. 9、从命令行运行postman脚本及生成测试报告
  13. 软件开发过程与项目管理(9.软件项目配置管理计划)
  14. Mac OS 使用asio库
  15. vue抽屉_vue 自定义抽屉组件 仿 iview
  16. QT 小数位有效数显示
  17. 在哪里写博客比较好?不同写作平台的横向对比
  18. Win10安装Fliqo翻页时钟屏保
  19. 线性代数(numpy.linalg)
  20. Apollo-无人驾驶自定位技术*

热门文章

  1. USNEWS美国大学计算机工程,想从事编程?2019年USNews美国大学计算机工程专业排名值得一看...
  2. 清华大学周伯文老师课题组招聘助理教授/博士后/工程师
  3. 【Mac】搜狗输入法干扰声音输出
  4. anki怎么设置学习计划_Anki:用这套记忆卡片,学习一切你背不下来的知识 #iOS #Android #PC...
  5. 巧用计算机课件,如何用电脑录制ppt讲解视频?
  6. SAP CO模块的英文缩写
  7. 用Photoshop去除图片中的原有文字
  8. MySQL查询日期为一年第几天第几周,天数周数反查日期
  9. Python制作回合制手游外挂简单教程(中)
  10. 记一次WebService调用踩的坑