jquery 设置margin-top 刷新之后就失效了

jquery 设置margin-top 刷新之后就失效了,第1张

我觉得最大的可能是你用jquery设置的margin-top没有加单位的原因,其次也可能有$('.logo').height()-$('.logo_img').height()缺少数值类型转换的因素。

要加上单位,像下面这样:

<script>

$(document).ready( function (){

$('.logo_img').css({

'margin-top':(($('.logo').height()-$('.logo_img').height())/2) + 'px'

})

})

</script>

保险起见的话,再加上类型转换:

<script>

$(document).ready( function (){

$('.logo_img').css({

'margin-top':((parseFloat($('.logo').height())-parseFloat($('.logo_img').height()))/2) + 'px'

})

})

</script>

还有,如果这个元素在页面中是唯一的,本人还是推荐用id去获取元素,这样用js选择器取值时也会更直接快速,保持良好的代码书写习惯,很重要。

一下是相关代码,JS中定义的变量margin就是你所说的每个div的间距,这样你就不用去设置margin-right了。

另外,在运行我贴上的代码的时候请应用jquery类库

<style type="text/css">

body, ul, li, h3 { margin: 0padding: 0list-style: nonefont: bold 12px "微软雅黑"}

/*瀑布流布局样式*/

#lxf-box { position: relative}

#lxf-box li { position: absolutebackground: #fffborder: solid 1px #ccctext-align: centerpadding: 10pxleft: 0pxtop: 0}

h3 { padding-top: 8px}

img { width: 200pxheight: autodisplay: blockborder: 0 }

/*css3动画*/

li { -webkit-transition: all .7s ease-out .1s-moz-transition: all .7s ease-out-o-transition: all .7s ease-out .1stransition: all .7s ease-out .1s }

</style>

<ul id="lxf-box">

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

<li><a ><img /></a>

<h3>图片标题</h3>

</li>

</ul>

<script>

/*

原理:1.把所有的li的高度值放到数组里面

2.第一行的top都为0

3.计算高度值最小的值是哪个li

4.把接下来的li放到那个li的下面

*/

var margin = 10//这里设置间距

var li=$("li")//这里是区块名称

varli_W = li[0].offsetWidth+margin//取区块的实际宽度(包含间距,这里使用源生的offsetWidth函数,不适用jQuery的width()函数是因为它不能取得实际宽度,例如元素内有pandding就不行了)

function liuxiaofan(){//定义成函数便于调用

var h=[]//记录区块高度的数组

var n = document.documentElement.offsetWidth/li_W|0//窗口的宽度除以区块宽度就是一行能放几个区块

for(var i = 0i <li.lengthi++) {//有多少个li就循环多少次

li_H = li[i].offsetHeight//获取每个li的高度

if(i <n) {//n是一行最多的li,所以小于n就是第一行了

h[i]=li_H//把每个li放到数组里面

li.eq(i).css("top",0)//第一行的Li的top值为0

li.eq(i).css("left",i * li_W)//第i个li的左坐标就是i*li的宽度

}

else{

min_H =Math.min.apply(null,h) //取得数组中的最小值,区块中高度值最小的那个

minKey = getarraykey(h, min_H)//最小的值对应的指针

h[minKey] += li_H+margin //加上新高度后更新高度值

li.eq(i).css("top",min_H+margin)//先得到高度最小的Li,然后把接下来的li放到它的下面

li.eq(i).css("left",minKey * li_W)//第i个li的左坐标就是i*li的宽度

}

$("h3").eq(i).text("编号:"+i+",高度:"+li_H)//把区块的序号和它的高度值写入对应的区块H3标题里面

}

}

/* 使用for in运算返回数组中某一值的对应项数(比如算出最小的高度值是数组里面的第几个) */

function getarraykey(s, v) {for(k in s) {if(s[k] == v) {return k}}}

/*这里一定要用onload,因为图片不加载完就不知道高度值*/

window.onload = function() {liuxiaofan()}

/*浏览器窗口改变时也运行函数*/

window.onresize = function() {liuxiaofan()}

</script>

</body>

</html>

首先将获取的margin-top转化为数值型 parseInt(获取的margin-top)=-20

然后再用Math.abs(获取的margin-top数字)=20

思路是先用parseInt()转化为整数

再用Math.abs()转化为正数

注意:jq与js可以共存,但不可以混用,这里jq中是可以使用js的


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11362997.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存