CSS는 구조적 내용의 복잡성과 반복을 줄이기 위해 웹 디자인에서 매우 널리 사용됩니다. 이 기사에서는 CSS 기반을 강화할 수 있는 26가지 CSS 기반 인터뷰 질문을 공유합니다.
(동영상 공유 학습: css video tutorial)
CSS는 Cascading Style Sheets의 약자로, HTML과 같은 마크업 언어를 기술하는 데 사용되는 스타일 시트 언어입니다. 작성되는 문서의 레이아웃입니다. . 웹페이지를 디자인하는 데 사용되는 세 가지 총사 중 하나이며, 나머지 두 가지는 HTML
및 Javascript
입니다. HTML
和Javascript
。
CSS 的设计目的是使样式和内容分离,包括布局、颜色和字体。这种分离可以提高内容的可访问性,在样式特征的规范中提供更多的灵活性和控制,通过在一个单独的. .css
文件中指定相关的 CSS,使多个 web 页面能够共享格式,并减少结构内容中的复杂性和重复。
它具有简单的语法,并使用大量的英文关键字来指定各种样式属性的名称。
既然我们已经讨论了CSS的基础知识,让我们来观察一下基于CSS的重要面试问题。
CSS(层叠样式表)是一种样式语言,对于 HTML 元素来说足够简单。 它在网页设计中非常流行,其应用在XHTML中也很常见。
CSS是在1997年开发的,作为一种web开发人员设计他们正在创建的web页面布局的方法。它的目的是让开发者将网站代码的内容和结构从视觉设计中分离出来。
这种结构和设计的分离允许HTML执行比原来更多的功能。
CSS的不同版本:
CSS1
CSS2
CSS2.1
CSS3
一个样式规则由三部分组成:
选择器–选择器是 HTML 标记,用于选择要设置样式的内容。 它根据其ID
,类和名称选择 HTML元素。
属性–属性是 HTML 标签的一种属性。 简而言之,所有 HTML 属性都转换为 CSS 属性。
值– CSS中的值定义CSS属性的一组有效值。
CSS 可以集成为三种方式
内联:直接在HTML元素上使用
<p style=”colour:skyblue;”>hello world</p>
外部:在工作空间中创建单独的CSS文件,然后在创建的每个web页面中链接它们
<head> <link rel="text/css" href="your_CSS_file_location"/> </head>
内部: web 页面的 head 元素在其中实现了内部 CSS。
<head> <style> P{ color : lime; background-color:black; } </style> </head>
万维网协会维护 CSS规范。
伪元素是添加到选择器的关键字,它允许一种样式,即所选元素的特定部分。CSS用于在HTML标记中应用样式,它允许在不影响实际文档的情况下对文档进行额外标记。它可以用来:
为第一个字母、行或元素设置样式。
插入内容
语法:
Selector: :pseudo-element{ Property1 :value; Property2 :value; }
CSS的优点是:
一致性 – CSS有助于构建一致的框架,设计人员可以使用该框架来构建其他站点。 因此,网页设计师的效率也提高了。
易于使用 – CSS 是非常容易学习和简化网站开发。所有代码都放在一个页面上,这意味着对代码行进行改进或编辑不需要重复修改多个页面.
*网站速度 *– 通常,一个网站使用的代码最多可以达到 2
页或更多。但是对于CSS,这不是问题。它只需要2-3
이제 CSS의 기본 사항을 논의했으므로 중요한 CSS 기반 면접 질문을 살펴보겠습니다.
CSS(Cascading Style Sheets) 는 HTML 요소에 사용할 수 있을 만큼 간단한 스타일 언어입니다. 이는 웹 디자인에서 매우 인기가 높으며 XHTML에서도 그 응용이 일반적입니다.
ID
, 클래스 및 이름을 기반으로 HTML 요소를 선택합니다. 🎜🎜🎜🎜🎜Attributes🎜 – 속성은 HTML 태그의 속성입니다. 즉, 모든 HTML 속성은 CSS 속성으로 변환됩니다. 🎜🎜🎜🎜🎜Values🎜 – CSS의 값은 CSS 속성에 대한 유효한 값 집합을 정의합니다. 🎜🎜//物理元素 <b>我想用b标签加粗</b> //逻辑元素 <strong>我想用strong标签加粗</strong> //两段文字都加粗了,而且视觉效果完全一样🎜🎜External🎜: 작업 공간에서 별도의 CSS 파일을 만든 다음 만드는 모든 웹 페이지에 연결합니다. 🎜
selector:pseudo-class{property:value;}🎜🎜Internal🎜: 웹 페이지의 헤드 요소에는 내부 CSS가 구현되어 있습니다. 🎜rrreee
2
페이지 이상일 수 있습니다. 하지만 CSS에서는 이것이 문제가 되지 않습니다. 2-3
줄의 코드만 필요하므로 웹사이트 데이터베이스가 깨끗하게 유지되고 웹사이트 로딩 문제가 제거됩니다. 🎜🎜🎜🎜🎜장치 호환성🎜 – 사람들이 인터넷에 접속하기 위해 다양한 유형의 스마트 장치를 사용함에 따라 반응형 웹 디자인이 필요합니다. 여기서 CSS의 역할은 웹페이지가 모든 장치에서 동일한 방식으로 표시되도록 반응성을 높이는 것입니다. 🎜🎜🎜🎜🎜다중 브라우저 지원🎜 – CSS는 다중 브라우저 지원을 제공하며 모든 주요 인터넷 브라우저와 호환됩니다. 🎜Repositioning – CSS를 사용하면 페이지에서 웹 요소 위치의 변경 사항을 정의할 수 있습니다. 구현을 통해 개발자는 페이지의 미적 매력이나 기타 고려 사항에 맞게 HTML 요소를 원하는 곳에 배치할 수 있습니다.
그라데이션은 두 이미지 사이에 중간 프레임을 만들어 첫 번째 이미지의 모양을 얻은 다음 두 번째 이미지로 전개하는 프로세스로, 주로 애니메이션 제작에 사용됩니다.
CSS 특이성은 요소가 사용해야 하는 스타일 선언을 결정하는 점수 또는 수준입니다. CSS에는 특정 수준의 선택기를 부여할 수 있는 네 가지 범주가 있습니다.
인라인 스타일
ID
클래스, 속성 및 의사 클래스
요소 및 의사 요소
CSS의 단점은 다음과 같습니다.
버전이 너무 많습니다 – HTML이나 Javascript와 같은 다른 매개변수에 비해 CSS에는 CSS1, CSS2, CSS2.1 등 다양한 버전이 있습니다. CSS3. 결과적으로 CSS는 특히 초보자에게 매우 혼란스럽습니다.
보안 부족 - CSS는 개방형 텍스트 기반 시스템이므로 덮어쓰는 것을 방지하는 보안 시스템이 내장되어 있지 않습니다. 읽기/쓰기 액세스 권한이 있으면 누구나 CSS 파일을 변경하고 링크를 변경할 수 있습니다.
Fragmentation - CSS를 사용하면 다른 브라우저에서는 작동하지 않을 수 있습니다. 따라서 웹사이트를 활성화하기 전에 웹 개발자는 여러 브라우저에서 프로그램을 실행하여 호환성을 테스트해야 합니다.
복잡성 – Microsoft FrontPage와 같은 타사 소프트웨어를 사용하면 CSS가 복잡해질 수 있습니다.
RWD(반응형 웹 디자인) 기술은 모바일, 태블릿, 데스크탑, 노트북과 같은 모든 화면 크기와 장치에서 완벽하게 작동하는 데 사용됩니다. 각 장치마다 다른 페이지를 만들 필요가 없습니다.
CSS 스프라이트의 이점은 다음과 같습니다.
다양한 작은 이미지를 하나의 이미지로 결합하여 웹 페이지 로딩 시간을 줄입니다.
HTTP 요청을 줄여 로드 시간을 줄입니다.
컨텍스트 선택자는 엄밀히 말하면 공백으로 구분된 태그 이름 집합인 descendant Combined Selector라고 합니다. 지정된 상위 요소의 하위 항목인 태그를 선택하는 데 사용됩니다. 태그의 계층 구조에 이러한 상위 "업스트림"이 있는 한 해당 태그가 선택됩니다. 태그와 상위 항목인 컨텍스트 사이에 몇 개의 수준이 있는지는 중요하지 않습니다.
점진적 향상의 개념은 낮은 수준의 브라우저에서 사이트 페이지의 사용성과 접근성을 보장하는 것을 기반으로 가장 기본적인 사용성부터 시작하는 것을 의미합니다. , 점차적으로 기능을 추가하고 사용자 경험을 개선합니다. 본질적으로 마크업 언어를 사용하여 페이지를 작성하고 스타일 시트를 통해 페이지 스타일을 제어하는 등 일상적인 개발 습관 중 일부는 모두 점진적인 향상 개념에 속하며 다음과 같은 새로운 기술의 사용도 포함됩니다. HTML5 및 CSS3 - 고급 브라우저용으로 페이지에 대한 사용자 경험을 풍부하게 향상시킵니다.
원활한 성능 저하의 개념은 먼저 최신 기술을 사용하여 고급 브라우저에 맞는 가장 강력한 기능과 사용자 경험을 구축한 다음 일상적으로 사용되는 하위 수준 브라우저의 한계를 기반으로 지원되지 않는 기능과 경험을 점차적으로 약화시키는 것을 의미합니다. life IE 개발에서 원활한 성능 저하의 일반적인 예는 먼저 Chrome용 페이지 코드를 작성한 다음 IE에서 예외를 수정하거나 IE에서 구현할 수 없는 기능을 제거하는 것입니다.
그래서 이 두 가지 개념적 방법은 다음과 같습니다. 실제로 우리의 일상적인 개발 작업에서 "점진적 향상"과 "부드러운 저하"라는 용어는 최근 몇 년 동안 대중화되기 시작했습니다. 현재 HTML5 및 CSS3의 실제 적용에서 이 두 가지 개념이 특히 중요합니다. 끊임없이 변화하는 새로운 기술을 사용하여 주류 브라우저에서 기본적인 사용성을 갖춘 사이트를 구축하고 고급 브라우저에 대한 경험을 향상시키는 방법은 무엇입니까? 개발 과정에서 우리가 명확히 해야 할 아이디어는 다음과 같습니다.
font-awesome
또는 Alibaba의 iconfont
와 같은 아이콘 라이브러리를 사용하여 HTML 웹 페이지에 아이콘을 추가할 수 있습니다. 인라인 HTML 요소에 지정된 아이콘 클래스의 이름을 추가해야 합니다. (<i></i>
또는 <span></span>
). 아이콘 라이브러리의 아이콘은 확장 가능한 벡터이며 CSS를 사용하여 사용자 정의할 수 있습니다. font-awesome
或者阿里的 iconfont
之类的图标库将图标添加到HTML网页。 我们必须将给定图标类的名称添加到任何内联HTML元素中。 (5a8028ccc7a7e27417bff9f05adf5932
或45a2772a6b6107b401db3c9b82c049c2
)。 图标库中的图标是可缩放的矢量,可以使用CSS进行自定义。
border-width
border-width
테두리 너비를 지정합니다. 🎜物理标签被称为表示标记,而逻辑标签对于外观是无用的。物理标签是较新的版本,而逻辑标签是旧的并且专注于内容。
如题,我们的标签元素写上后,浏览器就会渲染出结果,但不仅仅是这么简单
//物理元素 <b>我想用b标签加粗</b> //逻辑元素 <strong>我想用strong标签加粗</strong> //两段文字都加粗了,而且视觉效果完全一样
确实,文字加粗了,两者都达到了我们想要的目的,但是我们忽略了一个问题,既然b标签可以加粗,那么strong这个标签同样是加粗,存在的 意义又是什么呢?既然W3C定义了两个,它们之间的不同点是什么呢?它们之间的相同点又是什么呢?
物理元素
物理元素,又叫实体标签,它所做的是一种物理行为,比如上面我把一段文字用b标签加粗了,它所传达的给浏览器,告诉浏览器 我要加粗这段文字,从单词Bold中也可以看出来,英文中仅仅是加粗的意思,并没有其他作用。总结来说就是一句话: 物理元素就是告诉浏览器该怎么显示出来。
逻辑元素
逻辑元素,从英文字面上Strong就可以看出它是强调的意思,所以我们用这个逻辑元素(如上strong)来向浏览器传达 一个强调某段文字重要性的消息,说明此文字较为重要,也有利于搜索引擎收录。
Web标准主张XHTML不涉及具体的表现形式,“强调”可以用加粗来强调,也可以用别的方式强调,也可以通过css来改变strong的具体表现 ,还有就是并不是有了strong逻辑标签,就不用b标签来表示字体加粗了,b标签和strong标签默认情况下强调的效果一致,strong完全可以定义成别的样式,用来强调 效果,但是最好符合W3C标准,它更提倡内容与样式分离,所以单纯为了达到加粗而使用b标签不建议这样做, 从XHTML文档有意义性及用户体验角度来说,strong逻辑标签更加合适,而SEO方面,则针对优化情况而定。
CSS伪类是用来添加一些选择器的特殊效果。伪类的语法
selector:pseudo-class{property:value;}
CSS
和 SCSS
之间的区别如下:
CSS是一种用于设计web页面的样式语言,而SCSS用于为浏览器组合CSS样式表。
SCSS 提供了一些变量,可以使用这些变量来缩短代码,这是与 CSS 相比的一大优势。
嵌入式样式表的优点:
可以在一个文档中创建多种标签类型。
在复杂情况下,可以使用选择器和分组方法来应用样式。
无需额外下载。
嵌入式样式表的缺点:
无法控制多个文档。
不同的介质不区分大小写,因此它们具有不同的属性。 他们是:
aural - 用于语音和音频合成器
print - 用于打印机
projection - 用于方案展示,比如幻灯片
handheld - 用于小的手持的设备
screen - 用于电脑显示器
Font-style
Font-variant
Font-weight
Font-size/line-weight
Font-family
该指令告诉浏览器如何在HTML页面上渲染特定元素。 它由一个选择器和一个遵循规则集的声明块组成。 选择器可以附加到其他选择器,以通过规则集进行标识。
CSS 框架是一个库,它允许使用CSS语言进行更轻松,更符合标准的Web设计。 这些框架中的大多数至少包含一个网格以及更多功能和其他基于Javascript的功能。 一些著名的CSS框架有:ACSS,Bulma,YAML,Foundation
等。
英文原文地址:https://codersera.com/blog/top-css-interview-questions-and-answers/
更多编程相关知识,请访问:编程入门!!
위 내용은 CSS 기초를 강화하기 위해 수집할 가치가 있는 26가지 CSS 인터뷰 질문!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!