js修改行间距,主要是针对css样式的控制;
原生javascript的写法主要依靠style.lineHeight的属性,实例:
document.getElementById("aaa").style.lineHeight="100px"jquery的写法,修改行间距的写法实例:
$("#aaa").css("line-height","100px")这个不需要js,直接用css就可以了。letter-spacing 属性增加或减少字符间的空白(字符间距)。该属性定义了在文本字符框之间插入多少空间。由于字符字形通常比其字符框要窄,指定长度值时,会调整字母之间通常的间隔。因此,normal 就相当于值为 0。允许使用负值,这会让字母之间挤得更紧。当然,如果你一定要用js,它对应js中的属性是obj.style.letterSpacing。
一下是相关代码,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>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)