让元素不显示的方法

CSS

占空间

  1. visibility:hidden : 不可交互

  2. opacity:0 : 设置透明度,注意,设置透明度比较特殊,他是可交互的

  3. transform:scale(0) : 不可交互,缩放为0倍,注意transform是在绘制阶段才处理,也就是他不会影响元素的占位

  4. z-index: -1 : 不可交互,在定位元素/flex子项/grid子项设置z-index为-1,会被除了根元素的背景和边框和显式设置了z-index小于他的元素以外的元素覆盖起来,但是不可靠,因为需要保证有元素覆盖他,另外他不会影响布局,但是元素是可以覆盖在他上面的

    注意: z-index属性只有在定位元素,flex子项,grid子项上设置才有效

不占空间

  1. display: none : 不可交互,把html设置hidden属性本质上也是用的这个
  2. 宽高为0+overflow:hidden : 不可交互,注意设置margin为0,另外需要注意,因为如果是IE盒子不占位置,但是如果是标准盒子padding和border可能还是会占位(因为padding和margin还可能占位),另外如果设置了min-width/min-height隐藏会失效

特殊:

  1. 文本和背景色设置相同
  2. 移出屏幕: 即把位置设置成屏幕外如-99999

JS

不占空间:

  1. 元素.remove() / 父元素.removeChild(子元素) : 从dom中彻底移除,不过可以提前用变量备份一份元素,如果想拿回来只需要指定父元素,父元素.appendChild(元素)即可

占空间:

  1. 元素.innerHTML='' : 保留这个元素标签,移除内容(子标签也跟内容一样会被都移除),准确来说占不占空间取决于元素内容消失之后元素本身是否还占位置,并且css不会消失,即如果设置了padding或者margin或者width这种还是会占空间

**现代一般用模块化方式:**即写一个hidden类用js动态控制

js 复制代码
//先定义一个css类
.hidden{
    
}

//用js动态控制,比如想控制id为app的元素的显示隐藏
const node=document.getElementsById('app')
node.classList.add('hidden')//添加hidden类名,应用hidden样式
node.classList.toggle('hidden')//当前有hidden的话移除,当前无hidden的话添加
相关推荐
AI视觉网奇17 天前
three教学 3d资产拼接源代码
前端·css·css3
神明不懂浪漫18 天前
【第三章】CSS(一)——基础选择器、CSS的属性
前端·css·html·css3
智码看视界18 天前
老梁聊全栈:CSS3 高级特性—Flex/Grid 布局体系深度解析
前端·css3·布局·flexbox·grid·工程实践·全栈工程师
gz-郭小敏19 天前
优化横向滚动展示大量数据的时候数据晃动问题
前端·javascript·html·css3
贩卖黄昏的熊20 天前
flex 布局快速梳理
开发语言·javascript·css3·html5
川冰ICE21 天前
JavaScript实战④|天气查询应用,调用API与异步处理
javascript·css·css3
2501_9181269121 天前
一个上帝类程序作画
前端·css·css3
#麻辣小龙虾#22 天前
小学三年级语文小游戏
css·html·css3
Agatha方艺璇22 天前
前端开发技术复习笔记
vue·bootstrap·css3·html5·web
2501_9181269123 天前
小圆点踢足球
css·html·css3