网页占满整个屏幕_CSS网页背景图片等比例占满整个页面的解决方案
需求是这样的:
一个登录界面,让一张背景图片充满整个页面.需求看似非常简单,可是测试人员提的一个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网页背景图片等比例占满整个页面的解决方案相关推荐
- CSS网页背景图片等比例占满整个页面的解决方案
需求是这样的: 一个登录界面,让一张背景图片充满整个页面.需求看似非常简单,可是测试人员提的一个bug引起了我深入的思考.先上图,正常界面是这样的: 界面结构很简单,一个登录框,加一张背景图.我们都知 ...
- css设置背景图片等比例铺满整个页面
有次UI给我提出了bug说我的登录页的背景图变形了,后来查了下正确的背景图设置,如下: .login-box {width: 100%;height: 100%;background: url(&qu ...
- CSS背景图片平铺占满整个浏览器,且固定住不随滚动条移动
背景图片平铺占满整个浏览器,且固定住不随滚动条移动的样式写法 body {background-image: url(../images/bakimg.jpg); background-size: 1 ...
- CSS:实现background-image背景图片全屏铺满自适应
body {/* 加载背景图 */background-image: url(images/bg.jpg);/* 背景图垂直.水平均居中 */background-position: center c ...
- html添加背景图片并且填满div,css background-size与背景图片填满div(示例代码)
background-size与背景图片填满div 在开发中,常有需要将一张图片作为一个div的背景图片充满div的需求 background-size的取值及解释 background-size共有 ...
- 【UGUI】 全屏背景图片等比例拉伸自适应
效果如下: 首先感叹一下,UGUI的自适应做的还是非常不错的,RectTransform中提供了非常多种的自适应方式.对做界面来说还是很友好的. 如果界面上需要有个全屏的背景图(UI界面一般都是有的吧 ...
- vue.js 获取当前屏幕的宽度_vue 获取当前屏幕的宽度,图片等比例缩放,动态设置css样式...
vue 获取当前屏幕的宽度,图片等比例缩放 这个是一个背景图,点击对应的圆圈就会出现一个蒙层上面显示详情,但是只要当前窗口大小变化了,因为我的蒙层大小是固定的px,所以不会变,就不在图片对应的位置了 ...
- 3种CSS实现背景图片全屏铺满自适应的方式
来源 | https://www.fly63.com/ 一张清晰漂亮的背景图片能给网页加分不少,设计师也经常会给页面的背景使用大图,我们既不想图片因为不同分辨率图片变形,也不希望当在大屏的情况下,背景 ...
- html背景图片不重叠铺满,css背景图片怎么铺满
该方法适用于所有品牌的电脑. CSS设置拉伸背景图片铺满屏幕 新建一个html文件,命名为test.html,用于讲解CSS中如何设置拉伸背景图片铺满屏幕. 在test.html文件内,使用div标签 ...
最新文章
- Linux下的QQ截图
- 使用CAShapeLayer实现一个音量大小动态改变的控件
- zabbix监控规划及实施
- jquery weui 中alert弹出框在ios中跳动问题
- 检验例题_高考必考|化学工艺流程之物质的分离提纯及检验鉴别,轻松拿分
- Contest2162 - 2019-3-28 高一noip基础知识点 测试5 题解版
- 百度前端学院参考答案:第二十五天到第二十七天 倒数开始 滴答滴 滴答滴(2)...
- L3-019 代码排版 (30 分)-PAT 团体程序设计天梯赛 GPLT
- 成功的软件系统=成熟产品+全面配置+专业定制
- Android电池驱动【转】
- MySQL用C访问的示例代码
- 9、从命令行运行postman脚本及生成测试报告
- 软件开发过程与项目管理(9.软件项目配置管理计划)
- Mac OS 使用asio库
- vue抽屉_vue 自定义抽屉组件 仿 iview
- QT 小数位有效数显示
- 在哪里写博客比较好?不同写作平台的横向对比
- Win10安装Fliqo翻页时钟屏保
- 线性代数(numpy.linalg)
- Apollo-无人驾驶自定位技术*
热门文章
- USNEWS美国大学计算机工程,想从事编程?2019年USNews美国大学计算机工程专业排名值得一看...
- 清华大学周伯文老师课题组招聘助理教授/博士后/工程师
- 【Mac】搜狗输入法干扰声音输出
- anki怎么设置学习计划_Anki:用这套记忆卡片,学习一切你背不下来的知识 #iOS #Android #PC...
- 巧用计算机课件,如何用电脑录制ppt讲解视频?
- SAP CO模块的英文缩写
- 用Photoshop去除图片中的原有文字
- MySQL查询日期为一年第几天第几周,天数周数反查日期
- Python制作回合制手游外挂简单教程(中)
- 记一次WebService调用踩的坑