首页 > 前端开发 > 正文

web前端开发css规则 Web前端工程师要掌握的CSS技巧

2023-09-18 15:35:06 | 我爱编程网

今天我爱编程网小编为大家带来了web前端开发css规则 Web前端工程师要掌握的CSS技巧,希望能帮助到大家,一起来看看吧!

web前端开发css规则 Web前端工程师要掌握的CSS技巧

Web前端工程师应该知道的CSS隐藏页面元素的方法

今天小编要跟大家分享的文章是关于Web前端工程师应该知道的CSS隐藏页面元素的方法。用CSS隐藏页面元素有许多种方法。你可以将opacity
设为0、将visibility设为hidden、将display设为none或者将position设为absolute
然后将位置设到不可见区域。





你有没有想过,为什么我们要有这么多技术来隐藏元素,而它们看起来都实现的是同样的效果?每一种方法实际上与其他方法之间都有一些细微的不同,这些
不同决定了在一个特定的场合下使用哪一个方法。这篇教程将覆盖到那些你需要记住的细小不同点,让你根据不同情况选择上面这些方法中适合的方法来隐藏元素。正在从事web前端工作的小伙伴们来和小编一起学习一下吧!


一、opacity


opacity属性的意思是设置一个元素的透明度。它不是为改变元素的边界框(boundingbox)而设计的。这意味着将opacity设为0
只能从视觉上隐藏元素。而元素本身依然占据它自己的位置并对网页的布局起作用。它也将响应用户交互。


.hide{


opacity:0;}


如果你打算使用opacity
属性在读屏软件中隐藏元素,很不幸,你并不能如愿。元素和它所有的内容会被读屏软件阅读,就像网页上的其他元素那样。换句话说,元素的行为就和它们不透明时一致。


我还要提醒一句,opacity属性可以用来实现一些效果很棒的动画。任何opacity属性值小于1
的元素也会创建一个新的堆叠上下文(stackingcontext)。


看下面的例子:


看@SitePoint提供的例子“用opacity隐藏元素”


当你的鼠标移到被隐藏的第2个的区块上,元素状态平滑地从完全透明过渡到完全不透明。区块也将cursor属性设置为了
pointer,这说明了用户可以与它交互。


二、visibility


第二个要说的属性是visibility。将它的值设为hidden将隐藏我们的元素。如同opacity
属性,被隐藏的元素依然会对我们的网页布局起作用。与opacity唯一不同的是它不会响应任何用户交互。此外,元素在读屏软件中也会被隐藏。


这个属性也能够实现动画效果,只要它的初始和结束状态不一样。这确保了visibility
状态切换之间的过渡动画可以是时间平滑的(事实上可以用这一点来用hidden实现元素的延迟显示和隐藏——译者注)。


.hide{


visibility:hidden;}


下面的例子演示了visibility与opacity有怎样的不同:


看@SitePoint提供的例子“用visibility隐藏元素”


注意,如果一个元素的visibility被设置为hidden,同时想要显示它的某个子孙元素,只要将那个元素的visibility显式设置为
visible即可(就如例子里面的.o-hidep——译者注)。尝试只hover在隐藏元素上,不要hover在p
标签里的数字上,你会发现你的鼠标光标没有变成手指头的样子。此时,你点击鼠标,你的click事件也不会被触发。


而在 标签里面的

标签则依然可以捕获所有的鼠标事件。一旦你的鼠标移动到文字上,


本身变得可见并且事件注册也随之生效。


三、display


display属性依照词义真正隐藏元素。将display属性设为none
确保元素不可见并且连盒模型也不生成。使用这个属性,被隐藏的元素不占据任何空间。不仅如此,一旦display设为none
任何对该元素直接打用户交互操作都不可能生效。此外,读屏软件也不会读到元素的内容。这种方式产生的效果就像元素完全不存在。


任何这个元素的子孙元素也会被同时隐藏。为这个属性添加过渡动画是无效的,它的任何不同状态值之间的切换总是会立即生效。


不过请注意,通过DOM依然可以访问到这个元素。因此你可以通过DOM来操作它,就像操作其他的元素。


.hide{


display:none;}


看下面的例子:


@SitePoint提供的例子“用display隐藏元素”


你将看到第二个块元素内有一个

元素,它自己的display属性被设置成block,但是它依然不可见。这是
visibility:hidden和display:none的另一个不同之处。在前一个例子里,将任何子孙元素visibility显式设置成
visible可以让它变得可见,但是display不吃这一套,不管自身的display值是什么,只要祖先元素的display是
one,它们就都不可见。


现在,将鼠标移到第一个块元素上面几次,然后点击它。这个操作将让第二个块元素显现出来,它其中的数字将是一个大于0
的数。这是因为,元素即使被这样设置成对用户隐藏,还是可以通过JavaScript来进行操作。


四、position


假设有一个元素你想要与它交互,但是你又不想让它影响你的网页布局,没有合适的属性可以处理这种情况(opacity和visibility影响布局,
display不影响布局但又无法直接交互——译者注)。在这种情况下,你只能考虑将元素移出可视区域。这个办法既不会影响布局,有能让元素保持可以操作。下面是采用这
种办法的CSS:


.hide{


position:absolute;


top:-9999px;


left:-9999px;}


下面的例子阐明了怎样通过绝对定位的方式隐藏元素,并让它和前面的那个例子效果一样:


看@SitePoint提供的例子“用position属性隐藏元素”


这种方法的主要原理是通过将元素的top和left
设置成足够大的负数,使它在屏幕上不可见。采用这个技术的一个好处(或者潜在的缺点)是用它隐藏的元素的内容可以被读屏软件读取。这完全可以理解,是因为你只是将元素移到可视区域外面让用户无法看到它。


你得避免使用这个方法去隐藏任何可以获得焦点的元素,因为如果那么做,当用户让那个元素获得焦点时,会导致一个不可预料的焦点切换。这个方法在创建
自定义复选框和单选按钮时经常被使用。(用DOM模拟复选框和单选按钮,但用这个方法隐藏真正的checkbox和radio
元素来“接收”焦点切换——译者注)


五、clip-path


隐藏元素的另一种方法是通过剪裁它们来实现。在以前,这可以通过clip属性来实现,但是这个属性被废弃了,换成一个更好的属性叫做
clip-path。NitishKumar最近在SitePoint发表了“介绍clicp-path
属性”这篇文章,通过阅读它可以了解这个属性的更多高级用法。


记住,clip-path属性还没有在IE或者Edge下被完全支持。如果要在你的clip-path中使用外部的SVG
文件,浏览器支持度还要更低。使用clip-path属性来隐藏元素的代码看起来如下:


.hide{


clip-path:polygon(0px0px,0px0px,0px0px,0px0px);}


下面是一个实际使用它的例子:


看@SitePoint提供的例子“用clip-path属性隐藏元素”


如果你把鼠标悬停在第一个元素上,它依然可以影响第二个元素,尽管第二个元素已经通过clip-path隐藏了。如果你点击它,它会移除用来隐藏的
class,让我们的元素从那个位置显现出来。被隐藏元素中的文字仍然能够通过读屏软件读取,许多WordPress站点使用clip-path或者之前的
clip来实现专门为读屏软件提供的文字。


虽然我们的元素自身不再显示,它也依然占据本该占据的矩形大小,它周围的元素的行为就如同它可见时一样。记住用户交互例如鼠标悬停或者点击在剪裁区
域之外也不可能生效。在我们的例子里,剪裁区大小为零,这意味着用户将不能与隐藏的元素直接交互。此外,这个属性能够使用各种过渡动画来实现不同的效果。


结论


在这篇教程里,我们看了5种不同的通过CSS
隐藏元素的方法。每一种方法都与其他几种有一点区别。知道你想要实现什么有助于你决定采用哪一个属性,随着时间推移,你就能根据实际需求本能地选择最佳方式了。


以上就是小编今天为大家分享的关于Web前端工程师应该知道的CSS
隐藏页面元素的方法的文章,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助,想要了解更多web前端相关知识记得关注北大青鸟web培训官网。最后祝愿小伙伴们工作顺利!


我爱编程网

已赞过 已踩过 < 你对这个回答的评价是? 评论 收起

web前端开发css规则 Web前端工程师要掌握的CSS技巧

Web前端工程师要掌握的CSS技巧

今天小编要跟大家分享的文章是关于Web前端工程师要掌握的CSS技巧。正在从事web前端工作的小伙伴们快来和小编一起看一看吧,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助。


1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height;举个例子:





其实出现这种现象,我们可以巧用margin/padding的百分比值实现高度自适应(多用于占位,避免闪烁)当然该元素高度上的百分比是相对其父元素高度的百分比的,min-height及max-height也适用这条规律。





2、含有定位属性的元素,其top、bottom单位为百分比时,该百分比是相对于父元素的高度的。同理,left、right则是相对于父元素的宽度的。





这一点,我昨天在查资料写这篇文章—最全面的元素水平垂直居中方法汇总的时候就发现有个大牛也理解错了—-CSS布局奇淫技巧之_各种居中里面的第八点。3、边框宽度不允许使用百分比值这点就不解释了。4、width:100%当父容器里有绝对定位的子元素时,子元素设置width:100%实际上指的是相对于父容器的padding+content的宽度。当子元素是非绝对定位的元素时width:100%才是指子元素的content,其等于父元素的content宽度。





将上面子元素的position改成了relative后,其宽度就变成了parent宽度。





5、line-height你知道line-height:150%和line-height:1.5的区别吗?知道了就可以跳过此处,不知道继续看下面:举个例子:





上面可以看到line-height有单位时,子元素是继承父元素的line-height的,无单位时,其line-height等于无单位的数值乘以子元素本身的字体大小。显然为了不出现意外,还是建议首选无单位的。6、ex和ch单位ex:取当前作用效果的字体的x的高度,在无法确定x高度的情况下以0.5em计算;ch:以节点所使用字体中的“0”字符为基准,找不到时为0.5em;





ex和ch单位,类似于em和rem,依赖于当前的字体和字体大小。但是,不同的是,这两货是基于字体的度量单位,依赖于设定的字体。ch单位通常被定义为数字0的宽度。你可以在EricMeyers的博客里找到关于它的一些有意思的讨论,例如将一个等宽字体的字母”N”的宽度设置为40ch,那么在另一种类型的字体里它却可以包含40个字母。这个单位的传统用途主要是盲文的排版,但是除此之外,肯定还有可以应用他的地方。ex定义为当前字体的小写x字母的高度或者1/2的1em。很多时候,它是字体的中间标志。





x-height;theheightofthelowercasex这些单位有很多用途,大部分用于版式的微调。比方说,sup元素(上角文字标),可以通过position:relative;bottom:
1ex;实现。类似的方法,你可以实现一个下角文字标。浏览器默认的方式是利用上标和下标特定垂直对齐规则,但是如果你想更细粒度更精确得控制,你可以像下面这样做:Css代码





7、使用calc时运算符之间要有空格,否则可能无效。


以上就是小编今天为大家分享的关于Web前端工程师要掌握的CSS技巧的文章,希望本篇文章能对正在从事web前端相关工作的小伙伴们有所帮助。想要了解更多web前端相关知识记得关注北大青鸟web培训官网。最后祝愿小伙伴们工作顺利!


web前端开发css规则 Web前端工程师要掌握的CSS技巧

web前端里面什么是父级选择器?什么是子级选择器?

在Web前端开发中,CSS选择器是一种用来选取HTML元素并设置样式的工具。其中,父级选择器和子级选择器都是常用的CSS选择器类型。
父级选择器指的是在CSS中使用一个元素的父元素作为选择器的情况。其语法格式为:`parentSelector childSelector {...}`,其中 `parentSelector` 表示父级元素的选择器,`childSelector` 表示子级元素的选择器,中间需要加上空格分隔开。例如:
```css
.container p {
font-size: 16px;
}
```
在该示例中,`.container` 是父级选择器,`p` 是子级选择器。这条CSS规则将会选中所有位于 `.container` 元素内部的 `p` 元素,并设置它们的字号为 `16px`。
子级选择器则是指只选中某个元素下的直接子元素的选择器。其语法格式为:`parentSelector > childSelector {...}`,其中 `parentSelector` 表示父级元素的选择器,`childSelector` 表示子级元素的选择器,中间需要加上 `>` 符号分隔开。例如:
```css
ul > li {
list-style-type: none;
}
```
在该示例中,`ul` 是父级选择器,`li` 是子级选择器。这条CSS规则将会选中所有位于 `ul` 元素内部、且作为直接子元素的 `li` 元素,并设置它们的列表样式为无。
需要注意的是,在实际开发中,还需要考虑CSS选择器的性能、优先级和组合使用等问题,并根据具体需求进行定制化开发。

以上就是我爱编程网整理的web前端开发css规则 Web前端工程师要掌握的CSS技巧相关内容,想要了解更多信息,敬请查阅我爱编程网。
与“web前端开发css规则 Web前端工程师要掌握的CSS技巧”相关推荐
web前端开发css标签 Web前端工程师要掌握的CSS技巧
web前端开发css标签 Web前端工程师要掌握的CSS技巧

Web前端工程师要掌握的CSS技巧今天小编要跟大家分享的文章是关于Web前端工程师要掌握的CSS技巧。正在从事web前端工作的小伙伴们快来和小编一起看一看吧,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助。1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height

2023-09-12 11:53:53
web前端开发css项目 Web前端工程师要掌握的CSS技巧
web前端开发css项目 Web前端工程师要掌握的CSS技巧

web前端开发需要掌握哪些知识1.HTML知识要点:web工作原理、HTML4及HTML5、常见标签、相对路径与绝对路径、HTML5标签2.CSS+布局知识要点:CSS基本语法、基本选择器、复合选择器、背景图片、盒子模型、精灵图、常见网页布局、浮动定位、Flex布局、响应式布局、移动端适配、网页动画、CSS3新特性、Less预处理器3.ECMA基础知识要点:ECMA基本语

2023-09-15 17:21:50
web前端如何开发css Web前端工程师要掌握的CSS技巧
web前端如何开发css Web前端工程师要掌握的CSS技巧

Web前端工程师要掌握的CSS技巧今天小编要跟大家分享的文章是关于Web前端工程师要掌握的CSS技巧。正在从事web前端工作的小伙伴们快来和小编一起看一看吧,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助。1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height

2023-09-16 00:55:46
web前端开发css选区 Web前端工程师要掌握的CSS技巧
web前端开发css选区 Web前端工程师要掌握的CSS技巧

Web前端开发知识点之CSS的使用方式今天小编要跟大家分享的文章是关于Web前端开发知识点之CSS的使用方式。本文章小编从与HTML的结合方式、CSS语法、选择器以及盒子模型四个方面进行讲解。下面来和小编一起看一看吧!一、与HTML的结合方式CSS与HTML的结合方式一共有三种,分别是:外部样式、内部样式和内联样式。①外部样式当样式需要应用于很多页面时,外部样

2023-09-18 21:00:41
web前端开发css权重 Web前端工程师要掌握的CSS技巧
web前端开发css权重 Web前端工程师要掌握的CSS技巧

Web前端工程师要掌握的CSS技巧今天小编要跟大家分享的文章是关于Web前端工程师要掌握的CSS技巧。正在从事web前端工作的小伙伴们快来和小编一起看一看吧,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助。1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height

2023-09-18 22:45:18
web前端开发css代码 Web前端工程师要掌握的CSS技巧
web前端开发css代码 Web前端工程师要掌握的CSS技巧

Web前端工程师要掌握的CSS技巧今天小编要跟大家分享的文章是关于Web前端工程师要掌握的CSS技巧。正在从事web前端工作的小伙伴们快来和小编一起看一看吧,希望本篇文章能够对正在从事web前端工作的小伙伴们有所帮助。1、元素的margin的top、bottom及padding的top、bottom使用百分比作为单位时,其是相对父元素的宽度width的而不是我们想象的高度height

2023-09-19 06:55:08
web前端css怎么开发 Web前端工程师要掌握的CSS技巧
web前端css怎么开发 Web前端工程师要掌握的CSS技巧

web前端开发需要掌握哪些知识1.HTML知识要点:web工作原理、HTML4及HTML5、常见标签、相对路径与绝对路径、HTML5标签2.CSS+布局知识要点:CSS基本语法、基本选择器、复合选择器、背景图片、盒子模型、精灵图、常见网页布局、浮动定位、Flex布局、响应式布局、移动端适配、网页动画、CSS3新特性、Less预处理器3.ECMA基础知识要点:ECMA基本语

2023-09-21 04:47:10
web前端开发笔记css Web前端工程师要掌握的CSS技巧
web前端开发笔记css Web前端工程师要掌握的CSS技巧

前端知识点(基础篇)前端开发是指通过HTML、CSS、JavaScript等技术实现网站的界面、交互和效果等方面的开发。在这篇文章中,我们将介绍前端开发中的基础知识点,包括HTML、CSS和JavaScript。HTMLHTML是网页的基础,它定义了网页的结构和内容。下面是一些常用的HTML标签:1.标题标签HTML中有6个级别的标题标签,分别是h1~h6,用于定义

2023-09-24 16:03:26