js实现body背景图自动扩缩 光靠css几乎无法实现这样的效果

简介: js实现body背景图自动扩缩 光靠css几乎无法实现这样的效果

在网页中背景图是不可缺少的,无论是整体网页还是局部。熟悉前端的朋友都知道有个css属性叫background,用它可以指定一个图片作为背景。这个属性有很多参数。

定义和用法

background 简写属性在一个声明中设置所有的背景属性。

可以设置如下属性:

  • background-color
  • background-position
  • background-size
  • background-repeat
  • background-origin
  • background-clip
  • background-attachment
  • background-image

如果不设置其中的某个值,也不会出问题,比如 background:#ff0000 url('smiley.gif'); 也是允许的。

image.png

上面图我们重点关注background-size,它是管理图片大小的。看下它的介绍:

语法


background-size: length|percentage|cover|contain;
描述
length 设置背景图像的高度和宽度。第一个值设置宽度,第二个值设置高度。如果只设置一个值,则第二个值会被设置为 "auto"。
percentage 以父元素的百分比来设置背景图像的宽度和高度。第一个值设置宽度,第二个值设置高度。如果只设置一个值,则第二个值会被设置为 "auto"。
cover 把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。背景图像的某些部分也许无法显示在背景定位区域中。
contain 把图像图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域。

大家都会注意到cover,英文覆盖的意思,可是试过的人都会发现它并不能达到预期效果,图片很大的话只有一部分看得到,我们需要的是全部平铺就像我们windows电脑桌面有一种模式平铺那样的效果。

刚开始想纯粹靠css来实现行不通了,可是网上找了很多资料经过测试发现都不可以。要么是图片只显示一部分,要么就是网页窗口变动时无法做出相应的改变。 看样子还得依靠传统的办法,用js直接上,简单暴力。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width,initial-scale=1,shrink-to-fit=no">
  <script src="https://cdn.staticfile.org/jquery/1.11.2/jquery.min.js"></script>
  <title>js实现body背景图自动扩缩</title>
</head>
<style>
* {
  margin: 0px 0px;
  padding: 0px 0px;
}
body {
  background: url("images/bg1.png") no-repeat;
  background-size: 100% 100%;
}
</style>
<body>
</body>
<script>
$(window).bind("resize load", function() {
  $("body").css("height", $(window).height());
});
</script>
</html>

image.png

image.png

拉长

image.png

原图

目录
相关文章
|
2天前
|
安全 JavaScript
旋转木马轮播图 html+css+js
旋转木马轮播图 html+css+js
|
2天前
|
移动开发 前端开发 JavaScript
HTML5+CSS3+JavaScript网页实战
HTML5+CSS3+JavaScript网页实战
|
5天前
|
XML 前端开发 JavaScript
HTML、CSS、JavaScript有什么区别
HTML、CSS、JavaScript有什么区别
|
14天前
|
XML 前端开发 JavaScript
前端简介(HTML+CSS+JS)
前端简介(HTML+CSS+JS)
|
1天前
|
移动开发 JavaScript 前端开发
rem的适配方案,css文件和js文件的引入方式,特色小边框的制作,DS-Digital.ttf数字展示屏的使用方法:,自适应图片 background-size,jQuery爆bug,a和盒子居中,
rem的适配方案,css文件和js文件的引入方式,特色小边框的制作,DS-Digital.ttf数字展示屏的使用方法:,自适应图片 background-size,jQuery爆bug,a和盒子居中,
|
1天前
|
Web App开发 前端开发 JavaScript
技术心得记录:瀑布流的布局原理分析(纯CSS瀑布流与JS瀑布流)
技术心得记录:瀑布流的布局原理分析(纯CSS瀑布流与JS瀑布流)
|
2天前
|
前端开发 JavaScript
HTML+CSS+JS 倒计时动画效果
HTML+CSS+JS 倒计时动画效果
|
3天前
|
JavaScript 前端开发
js,jq,jquery删除css属性
js,jq,jquery删除css属性
7 0
|
Web App开发 JavaScript 前端开发
|
15天前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp小程序的校园竞赛管理系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp小程序的校园竞赛管理系统附带文章源码部署视频讲解等
164 63