国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
レッスン1:できる限り子供のコンポーネントを避けてください
レッスン2:あなたの小道具が互いに矛盾しないことを確認(rèn)してください
ホームページ ウェブフロントエンド CSSチュートリアル Reactコンポーネントの作成から學(xué)んだ2つのレッスン

Reactコンポーネントの作成から學(xué)んだ2つのレッスン

Apr 13, 2025 am 09:51 AM

Reactコンポーネントの作成から學(xué)んだ2つのレッスン

これは、Reactコンポーネントを構(gòu)築しない方法について學(xué)んだ教訓(xùn)をいくつか紹介します。これらは私が過去數(shù)か月にわたって出會ったものであり、特に多くのレガシーの技術(shù)的決定と多くの技術(shù)的負(fù)債を備えたデザインシステムに取り組んでいる場合、あなたに興味があるかもしれないと思っていました。

レッスン1:できる限り子供のコンポーネントを避けてください

多くのコンポーネントを備えた大きなデザインシステムで作業(yè)することについての1つのことは、最終的に次のパターンが本當(dāng)に迅速に問題になり始めることです。

 <card>
  <card.header> title </card.header>
  <card.body> <p>これはいくつかのコンテンツです</p> </card.body>
</card>

問題のある部分は、それらの子コンポーネント、card.body、card.headerです。この例は、物事が比較的単純であるため、ひどくはありません。コンポーネントがより複雑になったとき、物事がおかしくなります。たとえば、各子供のコンポーネントには、他の子どもたちと干渉する一連の複雑な小道具を持つことができます。

私の最大の問題の1つは、フォームコンポーネントの場合です。これを取る:

 
送信 キャンセル

もちろん、私は物事をかなり単純化していますが、エンジニアが2つのボタンを互いに隣に配置したいと思うたびに、ページにフォームがなかったとしても、フォームをインポートします。これは、フォームコンポーネント內(nèi)のすべてがインポートされることを意味し、それは最終的にパフォーマンスに悪いことです。たまたまシステム設(shè)計の実裝もそうです。

これにより、コンポーネントを文書化する際には、これらの各子供コンポーネントも文書化されていることを確認(rèn)する必要があるため、物事はさらに困難になります。

したがって、フォームを作成する代わりに、子コンポーネントにアクセスする代わりに、単純に新しいコンポーネントにする必要があります。そうすれば、常にフォームをインポートする必要はなく、レイアウトベースのコンポーネントを他のコンポーネントとは別に保持できます。

私は自分のレッスンを?qū)Wびました。これからは、できる限り子どものコンポーネントを完全に避けます。

レッスン2:あなたの小道具が互いに矛盾しないことを確認(rèn)してください

マンディマイケルは、このタイプスクリプトのように、小道具が互いにぶつかり、あらゆる種類の紛爭を引き起こす方法について素晴らしい記事を書きました。

インターフェイスプロップ{
  hidemedia?:ブールアリーン
  MediaisedgetOedge?:boolean
  Mediafullheight?:boolean
  VideoInline?:boolean
}

マンディは書いています:

これらの小道具の目的は、カード內(nèi)の畫像またはビデオのレンダリング方法を変更するか、メディアがまったくレンダリングされているかどうかを変更することです。それらを個別に定義することの問題は、コンポーネント機能を切り替える多くのフラグがあり、その多くが相互に排他的であることです。たとえば、マージンが隠されている場合、マージンを埋める畫像を作成することはできません。

これは、チームの設(shè)計システムで継承した多くのコンポーネントにとって間違いなく問題でした。ブールの小道具があらゆる種類の奇妙で予期しない方法でコンポーネントを動作させるコンポーネントがたくさんありました。開発中に、開発中にカードコンポーネントにあらゆる種類のバグがポップアップすることもありました。エンジニアは、どのプロップをオンにしてオフにするかを知らないためです。

マンディは次のソリューションを提供します。

タイプmediamode = 'hidden' | 「edgetoedge」| 「Fullheight」

インターフェイスプロップ{
  Mediamode:「Hidden」| 「edgetoedge」| 「Fullheight」
}

要するに、これらの初期オプションをすべて組み合わせると、簡単に拡張可能で、將來混亂を引き起こす可能性が低いよりクリーンなAPIがあります。

それでおしまい!これらの2つのレッスンについて簡単にメモしたかっただけです。これが私の質(zhì)問です。コンポーネントを作成したり、設(shè)計システムで作業(yè)したりすることに関して、何を?qū)Wびましたか?

以上がReactコンポーネントの作成から學(xué)んだ2つのレッスンの詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國語 Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫像を無料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中國語版

SublimeText3 中國語版

中國語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統(tǒng)合開発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

「レンダリングブロッキングCSS」とは何ですか? 「レンダリングブロッキングCSS」とは何ですか? Jun 24, 2025 am 12:42 AM

ブラウザは、特にインポートされたスタイルシート、ヘッダーのインラインCSS、および最適化されていないメディアクエリスタイルを使用して、ブラウザがインラインおよび外部CSSをデフォルトで主要なリソースとして表示するため、ページレンダリングをブロックします。 1.重要なCSSを抽出し、HTMLに埋め込みます。 2。JavaScriptを介して非クリティカルなCSSの読み込みを遅らせる。 3.メディア屬性を使用して、印刷スタイルなどのロードを最適化します。 4.リクエストを減らすためにCSSを圧縮およびマージします。ツールを使用してキーCSSを抽出し、REL = "Preload"非同期負(fù)荷を組み合わせ、過度の分割と複雑なスクリプト制御を避けるためにメディア遅延荷重を合理的に使用することをお勧めします。

Autoprefixerとは何ですか?それはどのように機能しますか? Autoprefixerとは何ですか?それはどのように機能しますか? Jul 02, 2025 am 01:15 AM

Autoprefixerは、ターゲットブラウザスコープに基づいてCSS屬性にベンダープレフィックスを自動的に追加するツールです。 1.エラーで接頭辭を手動で維持する問題を解決します。 2. PostCSSプラグインフォーム、CSSを解析し、プレフィックスする必要がある屬性を分析し、構(gòu)成に従ってコードを生成する屬性を分析します。 3.使用手順には、プラグインのインストール、ブラウザーリストの設(shè)定、ビルドプロセスでそれらを有効にすることが含まれます。 4。メモには、接頭辭を手動で追加しない、構(gòu)成の更新を保持すること、すべての屬性ではなくプレフィックスを維持することが含まれ、プリ??プロセッサでそれらを使用することをお勧めします。

conic-gradient()関數(shù)とは何ですか? conic-gradient()関數(shù)とは何ですか? Jul 01, 2025 am 01:16 AM

TheConic-Gradient()functionsscreateScular勾配の勾配は、測定されていることを確認(rèn)してください

粘著性ヘッダーまたはフッターを作成するためのCSSチュートリアル 粘著性ヘッダーまたはフッターを作成するためのCSSチュートリアル Jul 02, 2025 am 01:04 AM

to CreateStickyheadersandfooterswithcss、使用ポジション:Stickyforheaderswithtopvalueandz-index、ParentContainersdon’trestrictit.1.forstickyheaders:Setposition:Sticky、Top:0、Z-Index、およびBackgroundColor.2

CSSカスタムプロパティの範(fàn)囲は何ですか? CSSカスタムプロパティの範(fàn)囲は何ですか? Jun 25, 2025 am 12:16 AM

CSSカスタムプロパティの範(fàn)囲は宣言のコンテキストに依存します。通常、グローバル変數(shù)は次のように定義されます。一方、ローカル変數(shù)は、スタイルのコンポーネント化と分離のために特定のセレクター內(nèi)で定義されます。たとえば、.cardクラスで定義されている変數(shù)は、クラスとその子供に一致する要素でのみ使用できます。ベストプラクティスには以下が含まれます。1。使用:ルートトピック色などのグローバル変數(shù)を定義する。 2。コンポーネント內(nèi)のローカル変數(shù)を定義して、カプセル化を?qū)g裝します。 3.同じ変數(shù)を繰り返し宣言しないでください。 4.セレクターの特異性によって引き起こされる可能性のあるカバレッジの問題に注意してください。さらに、CSS変數(shù)はケースに敏感であり、エラーを回避するために使用する前に定義する必要があります。変數(shù)が未定義の場合、または參照が失敗した場合、フォールバック値またはデフォルト値の初期が使用されます。デバッグは、ブラウザ開発者を介して実行できます

モバイルファーストデザインに焦點を當(dāng)てたCSSチュートリアル モバイルファーストデザインに焦點を當(dāng)てたCSSチュートリアル Jul 02, 2025 am 12:52 AM

Mobile-firstcsssdesignRequiresTtingtheviewportatatag、使用、stylumsmallscreensup、optimingTouchTargets.first.second、cecond、em、orreminsteadofpixelseders.ths.thsthird、writebasethirdird、addtocontrolscaling.second、addtocontrolscaling.second

ロードスピナーとアニメーションを作成するためのCSSチュートリアル ロードスピナーとアニメーションを作成するためのCSSチュートリアル Jul 07, 2025 am 12:07 AM

CSSロード回転子を作成するには3つの方法があります。1。境界の基本回転子を使用して、HTMLとCSSを介してシンプルなアニメーションを?qū)g現(xiàn)します。 2。複數(shù)のポイントのカスタム回転子を使用して、異なる遅延時間を経てジャンプ効果を?qū)g現(xiàn)します。 3.ボタンに回転子を追加し、JavaScriptを介してクラスを切り替えて、読み込みステータスを表示します。各アプローチは、ユーザーエクスペリエンスを向上させるために、色、サイズ、アクセシビリティ、パフォーマンスの最適化などのデザインの詳細(xì)の重要性を強調(diào)しています。

本質(zhì)的にレスポンシブなグリッドレイアウトを作成する方法は? 本質(zhì)的にレスポンシブなグリッドレイアウトを作成する方法は? Jul 02, 2025 am 01:19 AM

本質(zhì)的な応答性のあるグリッドレイアウトを作成するために、COREメソッドはCSSGridのRepeat(auto-fit、minmax())モードを使用することです。 1.グリッドテンプレートコラムの設(shè)定:繰り返し(Auto-Fit、MinMax(200PX、1FR))繰り返して、ブラウザが列の數(shù)を自動的に調(diào)整し、各列の最小幅と最大幅を制限します。 2。ギャップを使用してグリッド間隔を制御します。 3.コンテナは、幅などの相対ユニットに設(shè)定する必要があります。100%、およびボックスサイズを使用してください。幅の計算エラーを回避し、マージンで中央に配置する必要があります。 4.オプションで、行の高さとコンテンツのアライメントを設(shè)定して、行などの視覚的な一貫性を向上させます

See all articles