隐藏标签点击显示

今天做了一个隐藏标签,点击显示。
由于要跟数据库做关联,根据数据库中的数据循环定义div标签

<c:forEach items="${grid }" var="g">
	<div>
	</div>
</c:forEach>

1、想到了用script脚本来处理事件,于是就有了

<script type="text/javascript" language="javascript">
    function click(name){
        var ui = document.getElementById("h");
        if (ui.style.display == "none"){
        	ui.style.display = "block";
        }
        if(ui.style.display == "block"){
        	ui.style.display = "none";
        }
    }
</script>

并将div元素定义id属性,问题是div标签数量是变化的,id属性唯一不能固定,用了其他不唯一的属性也不能定位标签。
2、于是就将id属性定义为变量,随着元素的变化,id也变化

<script type="text/javascript" language="javascript">
    function click(name){
        var ui = document.getElementById(name);
         if (ui.style.display == "none"){
            	ui.style.display = "block";
            }
            if(ui.style.display == "block"){
            	ui.style.display = "none";
            }
    }
</script>

同时事件也要传递相应参数

<a href="javaScript:click('${g.name }')">${g.name }</a>

可以定位到标签了,但是遇到不能将style.display属性变为"“或者” block"。
3、将两个if判断改为一个if和else,问题解决了

if (ui.style.display == "none"){
        	ui.style.display = "block";
        	//location.reload();
        }else{
        	ui.style.display = "none";
        }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值