この記事では、TypeScriptで再利用可能な基本クラスの作成を妨げ、TypeScript変換に関する以前の投稿を拡大しています。この投稿は独立していますが、リンクされた投稿はコードベースの書き換えと単体テストに関する貴重な洞察を提供します。
Node.jsのIoTおよびRoboticsライブラリであるJohnny-Fiveは、jQueryのようなアプローチを使用してハードウェアの相互作用を簡素化します。プラットフォーム間の違いを正常化し、高レベルの抽象化を提供します。 Arduino、Tessel、Raspberry Piなど、IOプラグインを介してさまざまなプラットフォームをサポートしています。 Raspberry PiをサポートするプラグインであるRaspi Ioは、Typescriptで書き直され、再利用可能な基本クラスの作成につながりました。
再利用可能な基本クラスの設計
クラスベースの継承に不慣れな人のために、基本クラスはサブクラスを拡張できる共通の構造と機能を提供します。この簡素化されたタイプスクリプトの例を考えてみましょう。
抽象クラスの自動車{ プライベート_speed:number = 0; プライベート_Direction:number = 0; パブリックドライブ(速度:番号):void { this._speed = speed; } パブリックターン(方向:番号):void { if(方向> 90 ||方向<p>この<code>Automobile</code>ベースクラスは、 <code>Sedan</code>クラスを作成するために拡張されています。両方のクラスのすべてのメソッドにアクセス可能です。同様に、Johnny-FiveのIOプラグイン用に<code>AbstractIO</code> Baseクラスが作成されました。</p><h3 id="Abstractioの実装"> Abstractioの実装</h3><p><code>AbstractIO</code> 、TypeScriptとJavaScriptのベストプラクティスの両方に準拠した基本クラスを提供するNPMパッケージです。 <code>MODES</code> Property and <code>digitalWrite</code>メソッドを調べてみましょう。</p><p> <code>MODES</code>プロパティは、数値定数からオブジェクトマッピングモード名(入力、出力など)です。 TypeScriptでは、列挙は理想的ですが、JavaScriptにはこの機能がありません。解決策? TypeScript列挙は内部で使用され、JavaScriptオブジェクトに外部からマッピングされます。</p><pre class="brush:php;toolbar:false"> enumモードをエクスポート{ 入力= 0、 出力= 1、 アナログ= 2、 pwm = 3、 サーボ= 4、 ステッパー= 5、 不明= 99 } public get modes(){ 戻る { 入力:mode.input、 出力:mode.output、 アナログ:mode.analog、 PWM:mode.pwm、 サーボ:mode.servo、 不明:mode.unknown }; }
サブクラスのオーバーライド( digitalWrite
など)を必要とする方法については、JavaScriptアプローチが採用されました。
Public DigitalWrite(PIN:String | number、value:number):void { 新しいエラーをスローします( `DigitalWriteは$ {this.name}`)によってサポートされていません。 }
TypeScriptには、除外されていないメソッドの警告がありませんが、これはTypeScriptとJavaScriptの両方で機能します。
重要な学習
TypeScriptとJavaScriptの両方を設計するプロセスは、これらの重要なポイントを強調しました。
- 一般的なベストプラクティスに優先順位を付けます。
- 競合が発生した場合は、TypeScriptのベストプラクティスを内部的に使用し、それらを外部的にJavaScriptにマッピングします。
- どちらも機能しない場合は、デフォルトでJavaScriptのベストプラクティスになります。
抽象クラスはJavaScriptではあまり有用ではなく、モジュール全体でダックタイピングがメンテナンスの課題を提示しました。図書館の消費者からの反復フィードバックは、設計を成功させるために重要でした。
結論
いくつかの妥協が必要ですが、TypeScriptユーザーとJavaScriptユーザーの両方に基本クラスを作成することができます。 AbstractIO
両方のコミュニティに成功し、バランスが衝突する可能性があることを示しています。
以上が実生活の例を使用して、タイプスクリプトで再利用可能なベースクラスを作成するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

CSSを備えたカスタムカーソルは素晴らしいですが、JavaScriptを使用して次のレベルに物事を引き出すことができます。 JavaScriptを使用して、カーソル状態間で移行し、カーソル内に動的テキストを配置し、複雑なアニメーションを適用し、フィルターを適用できます。

2025年には、互いに互いに跳ね返る要素を伴うインタラクティブなCSSアニメーションは、CSSにPongを実装する必要はありませんが、CSSの柔軟性とパワーの増加はLee&#039;の疑いを補強します。

CSSバックドロップフィルタープロパティを使用してユーザーインターフェイスをスタイルするためのヒントとコツ。バックドロップフィルターを複数の要素間でレイヤー化する方法を学び、それらを他のCSSグラフィカル効果と統合して、精巧なデザインを作成します。

まあ、SVG&#039;の組み込みのアニメーション機能は、計画どおりに非推奨されることはありませんでした。確かに、CSSとJavaScriptは負荷を運ぶことができる以上のものですが、以前のようにSmilが水中で死んでいないことを知っておくのは良いことです

イェーイ、テキストワラップのジャンプを見てみましょう:サファリテクノロジーのプレビューにかなり着陸してください!しかし、それがChromiumブラウザーでの仕組みとは異なることに注意してください。

このCSS-Tricksアップデートは、アルマナック、最近のポッドキャスト出演、新しいCSSカウンターガイド、および貴重なコンテンツを提供するいくつかの新しい著者の追加の大幅な進歩を強調しています。

ほとんどの場合、人々はTailwind&#039;の@Apply機能を紹介します。このように展示されたとき、@Applyはまったく有望な音をしません。だからobvio

馬鹿のように展開することは、展開に使用するツールと複雑さの報酬と複雑さの減少との間の不一致になります。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

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

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!
