分享好友 生活常识首页 频道列表

获取div的高度和宽度(讲解js设置元素style属性)

便民服务  2023-04-11 01:240

项目中有时候会遇到这个问题:一行有3个div,希望这3个div平分屏幕宽度,并且高度等于宽度。

第一个问题:平分屏幕宽度

可以对div设置百分比宽度,而不是直接用px宽度,这里用到了响应式设计的思想,可以参考这篇文章:自适应网页设计(Responsive Web Design)

第二个问题:动态设置高度和宽度一致

有两种方法,一种是用js动态设置,一种是直接用CSS设置

先看下html代码

  • some text

  • some text

  • some text

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23

公用的CSS

ul,li{

list-style: none;

}

* {

margin: 0;

padding: 0;

outline: 0

}

body {

margin: 0;

padding: 0;

-webkit-appearance: none;

font-family: “Helvetica Neue”, Helvetica, Arial, sans-serif;

font-size: 16px;

}

ul{

margin:10px;

}

.container {

display: inline-block;

position: relative;

width: 32%;

text-align: center;

}

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24

用js动态设置

var cw = $(‘.dummy’).width();

$(‘.dummy’).css({‘height’:cw+’px’});

$(window).resize(function() {

var cw = $(‘.dummy’).width();

$(‘.dummy’).css({‘height’:cw+’px’});

});

1 2 3 4 5 6

用CSS设置

.dummy {

padding-top: 100%;

width: 100%;

background: #333333;

}

1 2 3 4 5

CSS设置padding-top的原理:Use CSS to Specify the Aspect Ratio of a Fluid Element

/———————————————————

然后尝试对图片设置高度等于动态宽度

js方法很简单,跟上面的方法基本相同

  • some text

  • some text

  • some text

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20

.container {

display: inline-block;

position: relative;

width: 32%;

text-align: center;

}

.container img{

width: 100%;

height:100%;

}

1 2 3 4 5 6 7 8 9 10

var cw = $(‘.dummy’).width();

$(‘.dummy’).css({‘height’:cw+’px’});

$(window).resize(function() {

var cw = $(‘.dummy’).width();

$(‘.dummy’).css({‘height’:cw+’px’});

});

1 2 3 4 5 6

CSS方法

  • some text

  • some text

  • some text

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23

.container {

display: inline-block;

position: relative;

width: 32%;

text-align: center;

}

.dummy{

padding-top: 100%;

width: 100%;

background:url(images/test_3.wf) no-repeat;

-webkit-background-size: 100%;

background-size: 100%;

}

1 2 3 4 5 6 7 8 9 10 11 12 13

通过设置background可以实现。

div包含img的方法没有试验成功,以后继续尝试

/————————————-

还有一个问题,怎么设置div和img之间的padding,又能保证div宽度是屏幕宽度的三分之一?

查看更多关于【便民服务】的文章

展开全文
相关推荐
反对 0
举报 0
评论 0
图文资讯
热门推荐
优选好物
更多推荐文章
营销渠道的长度、宽度、密度分别指什么?
营销渠道的长度指商品从生产者手里最后转移到消费者手中所经历的环节多少。但是采用的渠道不同,经过的流通环节的多少也不一样。销售渠道宽度是指销售渠道的每个层次使用同种类型中间商数目的多少。一般来说,产品从生产者转移到消费者手中经过两个以上的同类

0评论2022-10-144726

更多推荐