HTML+CSS 面接の質問の概要 (回答 + 動画解説付き)

HTML+CSS 面接の質問の概要は次のとおりです (共通の重要なポイントは赤でマークされています)。

対応するビデオ説明はステーション B にあります。クリックすると無料で視聴できます。

2023年フロントエンド面接の高頻度質問・面接で必須となるHTML+CSSフロントエンド面接質問の詳細解説_bilibili_bilibili

目次

1. ブロック要素とインライン要素とは何ですか?

2. css3セレクター(理解)

3.CSSの優先度

4. Web標準とw3cの理解と理解

5.BFC

6. 要素を非表示にする方法と違いは何ですか?

7. ボックスを水平方向と垂直方向の中央に配置する方法

8. 聖杯レイアウトと両翼レイアウト

9. CSSボックスモデル

10. ブラウザのレンダリング機構

11. CSS3の新機能

フレックスの 12 の共通プロパティ

13. スプライトピクチャ(スプライトピクチャ)の原理とメリット・デメリット

14. 表示: なしと可視性: 非表示の違い

15. リンクと @import

16. セマンティクスについてのあなたの理解を教えてください 

1. ブロック要素とインライン要素とは何ですか?

  • 行内元素(span,a,img,input,strong,em,i,u,s,del,...)
  • ブロックレベルの要素 (div、p、h1、h2、h3、h4、h5、h6、ol、ul、table、li、form、dl、dt など)

2. css3セレクター(理解)

CSS3 の新しいセレクター

構造擬似クラスセレクター

p:first-child p タグの親要素内の最初の子要素。タグが p であるかどうかを確認する必要があります。p である場合のみ選択できます。

p:first-of-type p タグの親要素の最初の p

p:first-child は、親要素の最初の子である各要素を選択します

要素

p:nth-child(n) n は数値または数式、奇数、偶数、偶数です。

p:last-child は、親要素に属する最後の子要素をそれぞれ選択します

要素

p:nth-last-child(n) は最後の子要素からカウントを開始します

p:only-child は、親要素の唯一の子要素である各要素を選択します

要素

p:first-of-type は、その親に属する最初の要素を選択します

それぞれの要素

要素

:nth-of-type(n) n は数値または数式、奇数、偶数、偶数です。

p:last-of-type は、親要素の最後の p 要素を指定します

p:nth-last-of-type(n) は、最後の子要素から数えて、親要素の 2 番目の p 要素に属する各 p を指定します。

p:only-of-type は、親要素の特定のタイプの唯一の子要素である各 p 要素を指定します

属性セレクター

[attribute^=value] 属性 属性名 値 属性値は xx 属性を含み、XX で始まります

[attribute$=value] には xx 属性が含まれ、xx で終わります

[attribute*=value] には xx 属性が含まれており、属性値に xx が含まれている限り選択できます。

ステータス擬似クラスセレクター

:enabled 有効なフォーム要素

:disabled 無効なフォーム要素

:checked 選択されたフォーム要素 (ラジオ ボタンとチェック ボックスでのみ使用されます)

3.CSSの優先度

!重要 > インライン スタイル > ID セレクター > クラス セレクター > タグ セレクター。

  • 各セレクターには重みがあり、重みが大きいほど優先順位が高くなります。
  • 継承されたスタイルは、自己指定したスタイルよりも優先度が低くなります。
  • 重みが同じ場合、要素に近いスタイルの優先順位は、インラインスタイルシート(タグ内)>内部スタイルシート(現在のファイル内)>外部スタイルシート(外部ファイル内)の順となります。

4. Web標準とw3cの理解と理解

回答: タグは閉じられており、タグは小文字であり、ランダムな入れ子がないため、検索エンジンの検索確率が向上します。外部リンクの css および js スクリプトを使用すると、構造と動作が分離され、より幅広いデバイスからコンテンツにアクセスできるようになります。

コードとコンポーネントが少なく、保守が容易で改訂が容易で、ページのコンテンツを変更する必要がありません。

5.BFC

BFCのコンセプト

[ブロックレベルの書式設定コンテキスト] とも呼ばれます。簡単に言うと、BFC は完全に独立した空間 (レイアウト環境) であり、空間内のサブ要素は外部のレイアウトに影響を与えません。

BFCとはCSSレイアウトの概念で、内部の要素が外部の要素に影響を与えない環境のことです。

BFC レイアウト ルール

内箱は縦方向に順番に配置されます。

ボックスの垂直距離はマージンによって決まります。同じ BFC に属する 2 つの隣接するボックスの余白は重なり合います。

各ボックス (ブロック ボックスとライン ボックス) のマージン ボックスの左側は、それを含むブロックの境界ボックスの左側に接しています (左から右への書式設定の場合、それ以外の場合はその逆です)。これは浮きがあった場合にも当てはまります。

BFC エリアはフロート ボックスと重なりません。

BFC はページ上で分離された独立したコンテナであり、コンテナ内のサブ要素は外部の要素には影響しません。およびその逆。

BFC の高さを計算するときは、浮動要素も計算に参加します。

BFC の作成方法

1. float の値は none ではありません。

2. 位置の値は静的でも相対的でもありません。

3. display の値は、inline-block、table-cell、flex、table-caption、または inline-flex です。

4. オーバーフローの値は表示されません

BFCの役割(どのような問題を解決するのか)

  1. 余白の重なりを防止する
  2. フロート要素を含めることができます - 内部フロートをクリアします
  3. 適応型 2 列レイアウト
  4. 要素がフロート要素によって覆われるのを防ぐことができます

6. 要素を非表示にする方法と違いは何ですか?

  1. Visibility: hidden; この属性は単に要素を非表示にしますが、要素が占有するスペースはまだ存在します。
  2. 不透明度: 0; CSS3 属性、0 を設定すると要素を完全に透明にすることができますが、ページ レイアウトは変更されません。さらに、要素がクリック イベントなどのイベントにバインドされている場合、この領域をクリックするとクリックがトリガーされることもありますイベント。
  3. display: none; 要素は非表示になり、要素の位置を占めなくなります。ページレイアウトを変更させていただきます。
  4. transform:scale(0); 要素を無限に小さくスケールするように設定すると、要素は非表示になり、要素の元の位置が保持されます。

7. ボックスを水平方向と垂直方向の中央に配置する方法

4 つの方法:

絶対配置を使用して、まず要素の左上隅を上:50% および左:50% を通じてページの中央に配置し、次に移動によって要素の中心点をページの中央に調整します。

.div { 位置: 絶対; 幅: 200ピクセル;高さ: 200ピクセル; 背景: サーモン。左: 50%;上: 50%; 変換: 変換(-50%, -50%); }

絶対配置を使用し、4方向の値を0に設定し、マージンを自動に設定します。幅と高さは固定なので、対応する方向を等分割し、水平方向と垂直方向のセンタリングが可能です。達成。この方法は、ボックスに幅と高さがある場合に適しています。

.div { 位置: 絶対;幅: 200ピクセル;高さ: 200ピクセル; 左: 0;右: 0;上: 0;下: 0;マージン: 自動;}

絶対配置を使用して、まず要素の左上隅を上:50% および左:50% を通じてページの中央に配置し、次に負のマージン値を使用して要素の中心点をページの中央に調整します。この方法は、ボックスの幅と高さがわかっている状況に適しています。

.div { 位置: 絶対; 幅: 200ピクセル;高さ: 200ピクセル; 左: 50%。トップ: 50%; マージン左: calc(-200px / 2); マージントップ: calc(-200px / 2); }

フレックス レイアウトを使用して、align-items:center と justify-content:center を使用してコンテナの垂直方向と水平方向の配置を中央に設定すると、その子要素も垂直方向と水平方向の中央に配置できます。

.div { 幅: 100%; 高さ: 100%; ディスプレイ: フレックス; コンテンツの位置揃え: 中央; 整列項目:中央; }

8. 聖杯レイアウトと両翼レイアウト

違い: Holy Grail Layout は、中央の div の左右の内側のマージンを設定し、次に左右の div を配置し、中央の div をブロックしないように左右の属性を設定します。Double Flying Wing レイアウトは、内側にサブ div を直接作成します。コンテンツを配置するための中央の div。 、サブ div の左と右のマージンをそれぞれ設定して、左と右の列 div 用のスペースを残します。

聖杯のレイアウト: 左側と右側は固定、中央は適応型で、レンダリングは次のとおりです。

効果:

Holy Grail レイアウトと Double Flying Wings レイアウトは、両側に広い上部と適応型の中央列を備えた 3 列レイアウトであるという同じ問題を解決します。中央の列は優先順位を付けるためにドキュメント フローの前に配置する必要があります。レンダリングへ。

違い:

聖杯レイアウトとダブルウィングレイアウトの問題の解決策は、前半では同じです。つまり、3 つの列すべてをフロートさせますが、左右の列にマイナスのマージンを追加して並べます。中央の列 div を使用して 3 列のレイアウトを形成します。

違いは、「中央列の div の内容がブロックされない」問題を解決するためのさまざまなアイデアにあります。

Holy Grailレイアウトは、中央divのコンテンツがブロックされないように、中央divの左右のpadding-leftとpadding-rightを設定した後、position:relativeで左右のdivの相対レイアウトを使用します。左右の列 div が移動後に中央の div をブロックしないように、それぞれ right 属性と left 属性を一致させます。

ダブルウイングレイアウトでは、ミドルdivの内容が遮られることを防ぐため、ミドルdivのすぐ内側にサブdivを作成し、コンテンツを配置します。左右の列 div 用のスペースを残すために使用されます。

聖杯レイアウトコード:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>圣杯布局</title>
    <style>
        #bd {
            padding: 0 200px 0 180px;
            height: 100px;
        }
        #middle {
            float: left;
            width: 100%;
            height: 500px;
            background: blue;
        }
        #left {
            float: left;
            width: 180px;
            height: 500px;
            margin-left: -100%;
            background: #0c9;
            position: relative;
            left: -180px;
        }
        #right {
            float: left;
            width: 200px;
            height: 500px;
            margin-left: -200px;
            background: #0c9;
            position: relative;
            left: 200px;
        }
    </style>
</head>
<body>
<div id="bd">
        <div id="middle">middle</div>
        <div id="left">left</div>
        <div id="right">right</div>
    </div>
</body>
</html>

両翼レイアウト

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>双飞翼布局</title>
    <style>
        .out,.left,.right{
            float: left;
            height: 200px;
        }
        .out{
            width: 100%;
            background-color: #eee;
        }   
        .main {
            background-color: pink;
            margin: 0 200px;
            height: 200px;
        }
        .left {
            width: 200px;
            background-color: skyblue;
            margin-left: -100%;
        }
        .right {
            width: 200px;
            background-color: skyblue;
            margin-left: -200px;
        }
    </style>
</head>
<body>
    <div class="out">
        <div class="main">main</div>
    </div>
    <div class="left">left</div>
    <div class="right">right</div>
</body>
</html>

後でまとめますが、ダブルウィングレイアウトの本質は聖杯レイアウトと同じで、どちらもマイナスのマージンを設定することで要素の配置を実現します。

  • 違いは HTML の構造にあり、Shuangfeiyi では中央の要素の内側にミドルインナーを設定し、その左右のマージンを設定しますが、Holy Grail レイアウトではパディングを使用して両側の要素のカバレッジを除外します。
  • 二重飛行翼レイアウトには追加の HTML 構造を含めることができますが、左右の要素の位置を設定する必要はありません。

9. CSSボックスモデル

CSS ボックス モデルは基本的に HTML 要素をラップするボックスであり、ボックスは内側から外側に、content、padding、border、margin の 4 つの属性で構成されます。

2つのボックスモデルの違い

標準ボックスモデル:

幅 = コンテンツの幅

高さ = コンテンツの高さ

奇妙なボックスモデル:

width = コンテンツの幅 + パディングの幅 + ボーダーの幅

これら 2 つのモデルを CSS で設定する方法

標準ボックスモデル

ボックスのサイズ設定: コンテンツボックス

奇妙なボックスモデル:

ボックスのサイズ変更: ボーダーボックス

標準 CSS ボックス モデルを導入しますか? IE の下位バージョンのボックス モデルとの違いは何ですか?

CSS ボックス モデル: マージン、パディング、ボーダー、コンテンツ領域 (幅と高さ) の 4 つの属性で構成されます。

標準 CSS ボックス モデルは、ローエンド IE CSS ボックス モデルとは異なります。幅と高さが異なります。

標準 CSS ボックス モデルの幅と高さは、コンテンツ領域の幅と高さです。

IE CSS ボックス モデルの幅と高さのパディング + 境界線 + コンテンツ領域。

10. ブラウザのレンダリング機構

1. Web ページの生成プロセス:

Webページの生成プロセスは大きく5つのステップに分かれます。

  1. HTMLコードをDOMに取り込む
  2. CSS コードを CSSOM (CSS オブジェクト モデル) に変換する
  3. DOM と CSSOM を組み合わせてレンダリング ツリーを生成します (各ノードの視覚情報を含む)
  4. レイアウトを生成します。つまり、すべてのレンダリング ツリーのすべてのノードの平面合成です。
  5. 画面上にレイアウト(ペイント)を描画します

  これら 5 つのステップのうち、ステップ 1 ~ 3 は非常に速く、ステップ 4 と 5 が最も時間がかかります。

  「レイアウトの生成」(フロー)と「描画」(ペイント)の2つの工程を総称して「レンダリング」と呼びます。

11. CSS3の新機能

css3の新機能

説明する

ボックスシャドウ

ボックスシャドウ

境界半径

フィレ

ボックスのサイジング

ボックスモデル

線形グラデーション、放射状グラデーション

勾配

遷移

遷移

アニメーション化する

アニメーション

変身

2D変換/3D変換

アイコンフォント

フォントアイコン

フレックス

柔軟なレイアウト

フレックスの 12 の共通プロパティ

flex の共通プロパティ

説明する

* フレックス方向

コンテナの主軸の方向を設定します。

* フレックスラップ

コンテナが十分に入るかどうか、ラップするかどうか(なし/上/下)を設定するために使用されます。

* コンテンツの正当化

コンテナ内のコンテンツの配置を設定するために使用されます

* アイテムを揃える

コンテナ全体の配置を設定するために使用されます

コンテンツの整列

複数の軸の位置合わせを定義します。プロジェクトに軸が 1 つしかない場合、このプロパティは効果がありません。

フレックスフロー

flex-deriction プロパティと flex-wrap プロパティの略称で、デフォルト値は [row nowrap] です。

13. スプライトピクチャ(スプライトピクチャ)の原理とメリット・デメリット

英語名は css スプライトで、通常は「CSS 画像の結合」または「CSS テクスチャの配置」として解釈されますが、実際には、Web ページ内の背景画像を画像ファイルに統合し、CSS の「background-画像」に

「background-repeat」と「background-position」を組み合わせて背景を配置します。background-positionは数値を使用して背景画像の位置を正確に特定します。一般的な小さなアイコンに適していますが、大きな背景や大きなレイアウトの背景には適していません

アドバンテージ:

(1) Web ページの http リクエストを削減し、ページのパフォーマンスを大幅に向上させます。

(2) 写真のネーミングの問題

欠点:

(1) コンテナのサイズは、背景画像要素の位置に合わせて制限する必要があり、計算が必要です

14. 表示: なしと可視性: 非表示の違い

1. さまざまな機能

Visibility: hidden----要素を非表示にしますが、Web ページ内でその要素が占めるべき位置を占めます。

display: none ----要素の表示を none に設定します。つまり、要素は Web ページ内のどの位置も占めません。

2. 使用後の HTML 要素の変化

Visibility:hidden、この属性を使用した後、HTML 要素 (オブジェクト) は視覚的に見えなくなる (完全に透明になる) だけであり、それが占める空間的位置は依然として存在します。つまり、高さや幅などの属性値が残ります。 。

display:none を使用すると、HTML 要素 (オブジェクト) の幅、高さ、その他の属性値が「失われます」。

3. さまざまな定義

Visibility 属性は、要素が表示されるかどうかを指定します。

display 属性は、レイアウトの作成時に要素によって生成される表示ボックスのタイプを定義するために使用されます。

15. リンクと @import

a. 所属: リンクは HTML タグ、@import は CSS によって提供されます

  b. 読み込みの違い: ページが読み込まれるとき、リンクも同時に読み込まれますが、@import によって導入された CSS はページが読み込まれた後に読み込まれます。  

  c. 互換性: リンクには互換性の問題はありませんが、@import は IE5 未満のブラウザと互換性がありません。

  d. Link は、JS 操作 dom を通じてリンク タグを挿入してスタイルを変更できますが、@import はできません。

16. セマンティクスについてのあなたの理解を教えてください

  コンテンツの構造に応じて適切なセマンティック タグを使用すると、コードの可読性と保守性を向上させながら、ブラウザ クローラーとマシンの解析が向上します。

おすすめ

転載: blog.csdn.net/xm1037782843/article/details/131372485