JavaScript控制元素(标签)的显示与隐藏

使用JavaScript有多种方式来隐藏元素:

方式一、使用HTML 的hidden 属性,隐藏后不占用原来的位置

hidden 属性是一个 Boolean 类型的值,如果想要隐藏元素,就将值设置为 true,否则就将值设置为false

【HTML hidden 属性(Attribute):https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/hidden 】

var t = document.getElementById('test'); //选取id为test的元素

t. hidden = true;// 隐藏选择的元素

t. hidden =false;//显示

下面是使用方式一的示例源码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>显示与隐藏方式一</title>
    </head>
    <body>
        <button type="button" onclick="show()">显示文本区域</button>
        <button type="button" onclick="hide()">隐藏文本区域</button>
        <br>
        <textarea id="output" cols="70" rows="6" >雪景</textarea>
        <h3>使用HTML 的hidden 属性,文本区域隐藏后不占用原来的位置</h3>
        <img id="pic" src="./雪景.jpg">        
        <script>
            function show(){
                var t = document.getElementById('output');//选取id为test的元素
                t.hidden=false; 
            }

            function hide(){
                var t = document.getElementById('output');//选取id为test的元素
                t.hidden=true; // 设置隐藏元素             
            }

        </script>
   </body>
</html>

保存文件名为:元素(标签)的显示与隐藏方式一.html,用浏览器打开效果:

​​

方式二、使用元素style 对象的display属性,隐藏后不占用原来的位置

style 对象代表一个单独的样式声明(style statement)。

【Style display 属性(Property):https://developer.mozilla.org/en-US/docs/Web/CSS/displayhttps://www.w3schools.cn/jsref/prop_style_display.asp 提示,将网址中的cn改为com就变成英文页面】

var t = document.getElementById('test'); //选取id为test的元素

t.style.display = 'none';// 隐藏选择的元素

t.style.display = 'block';// 以块级样式显示

下面是使用方式二的示例源码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>显示与隐藏方式二</title>
    </head>
    <body>
        <button type="button" onclick="show()">显示文本区域</button>
        <button type="button" onclick="hide()">隐藏文本区域</button>
        <br>
        <textarea id="output" cols="70" rows="6" >雪景</textarea>
        <h3>使用元素style 对象的display属性,文本区域隐藏后不占用原来的位置</h3>
        <img id="pic" src="./雪景.jpg">
        <script>
            function show(){
                var t = document.getElementById('output');//选取id为test的元素
                t.style.display = 'block'; 
            }

            function hide(){
                var t = document.getElementById('output');//选取id为test的元素
                t.style.display =  'none';// 隐藏选择的元素               
            }

        </script>
   </body>
</html>

保存文件名为:元素(标签)的显示与隐藏方式二.html,用浏览器打开效果:

​​

方式三、使用元素style 对象的visibility属性,隐藏后其位置和大小仍被占用(只是显示为空白)

【Style visibility 属性(Property):https://developer.mozilla.org/en-US/docs/Web/CSS/visibilityhttps://www.w3schools.cn/jsref/prop_style_visibility.asp 】

var t = document.getElementById('test'); //选取id为test的元素

t.style.visibility = 'hidden';// 隐藏元素

t.style.visibility = 'visible';// 显示元素

下面是使用方式三的示例源码

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>显示与隐藏方式三</title>
    </head>
    <body>
        <button type="button" onclick="show()">显示文本区域</button>
        <button type="button" onclick="hide()">隐藏文本区域</button>
        <br>
        <textarea id="output" cols="70" rows="6" >雪景</textarea>
        <h3>使用元素style 对象的visibility属性,文本区域隐藏后其位置和大小仍被占用(只是显示为空白)</h3> 
        <img id="pic" src="./雪景.jpg">        
        <script>
            function show(){
                var t = document.getElementById('output');//选取id为test的元素
                t.style.visibility = 'visible'; 
            }

            function hide(){
                var t = document.getElementById('output');//选取id为test的元素
                t.style.visibility = 'hidden';// 隐藏元素              
            }

        </script>
   </body>
</html>

保存文件名为:元素(标签)的显示与隐藏方式三.html,用浏览器打开效果:

​​

小结:这三种方式的区别效果体现在:

方式一和方式二隐藏后不占用原来的位置,方式三进行隐藏后元素位置和大小仍被占用(只是显示为空白)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学习&实践爱好者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值