国产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ù)か月にわたって出會(huì)ったものであり、特に多くのレガシーの技術(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è)計(jì)の実裝もそうです。

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

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

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

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

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

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

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

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

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

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

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

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

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

それでおしまい!これらの2つのレッスンについて簡単にメモしたかっただけです。これが私の質(zhì)問です。コンポーネントを作成したり、設(shè)計(jì)システムで作業(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

強(qiáng)力な 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ù)荷を組み合わせ、過度の分割と複雑なスクリプト制御を避けるためにメディア遅延荷重を合理的に使用することをお?jiǎng)幛幛筏蓼埂?/p>

外部対內(nèi)部CSS:最良のアプローチは何ですか? 外部対內(nèi)部CSS:最良のアプローチは何ですか? Jun 20, 2025 am 12:45 AM

TheBestAppRoachforCSDependsonTheProject'sSpecificNeeds.forLargerProjects、externalCssissisbetterduetoMaintainasiladability; forsmallerProjectsOrsingLe-PageApplications、internalcsSmightBemoresuitable.it

私のCSSは小文字でなければなりませんか? 私のCSSは小文字でなければなりませんか? Jun 19, 2025 am 12:29 AM

いいえ、CSSDOESNOTHAVETOBEINLOWERCASE。

CSSケース感度:重要なことを理解する CSSケース感度:重要なことを理解する Jun 20, 2025 am 12:09 AM

cssismostlycase-inssensitive、buturlsandfontfamilynamesarecase-sensitive.1)propertiesandvalueslikecolor:red; areotcase-sensitive.2)urlsmustmatchtheserver'scase、例えば、/畫像/logo.png.3)

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

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

CSSカウンターとは何ですか? CSSカウンターとは何ですか? Jun 19, 2025 am 12:34 AM

csScountersCantAnationally-bersectionSandLists.1)usecounter-resettoinitialize、counter-incrementtoincrease、andcounter()orcounters()todisplayvalues.2)を組み合わせたjavascriptfordynamiccontenttoensureaCurateupdatesと組み合わせます。

CSS:ケースはいつ重要ですか(いつそうではありませんか)? CSS:ケースはいつ重要ですか(いつそうではありませんか)? Jun 19, 2025 am 12:27 AM

CSSでは、セレクターと屬性名はケースに敏感ですが、値、名前の色、URL、およびカスタム屬性はケースに敏感です。 1.バックグラウンドカラーや背景色など、セレクターと屬性名はケース非感受性です。 2。値の16進(jìn)數(shù)色は大文字と小文字を區(qū)別しますが、赤と赤などの名前の色は無効です。 3. URLは癥例に敏感であり、ファイルロードの問題を引き起こす可能性があります。 4.カスタムプロパティ(変數(shù))はケースに敏感であり、使用する場合はケースの一貫性に注意を払う必要があります。

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

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

See all articles