プロジェクトをAngular 1からReactに移行した方法

みなさんこんにちは!







プロジェクトをAngular 1からReactに移行するために使用した経験とツールを共有したいと思います。







TLTR: Angularコンポーネント(コントローラー+テンプレート)をReactコンポーネントに変換できるモジュールを作成しました。







ホリバーラのためではない



この記事では、なぜ、どのフレームワークが優れているかを証明しません。 はい、React以外にもVue、Angular 6が既にリリースされています。また、Ember、Svelteなども多くあります。一般的に、タスクをどのように解決したかをお伝えしたいと思います。私の経験と経験が誰かに役立つことを願っています。







プロジェクト



それぞれに、別のフレームワーク/ライブラリに切り替える独自の理由があります。 私の会社では、主なプロジェクトが書かれていました Reactがテーブルの下を歩いたとき かなり前に、Angular 1.xがこのために選択されました。 時には痛み(ダイジェストサイクル、ウォッチャーとの魔法、Angularの約束)をもたらしましたが、全体として彼は仕事をしました。







メインプロジェクトのモバイルバージョンを含むすべての新しい関連プロジェクトは、多数のRedux + React + Typescript + CSSモジュールを使用します。 その結果、コンポーネントとスタイルのライブラリが登場し、すべてのプロジェクトが厳密に標準化され、新しいコンポーネントとサブプロジェクトの開発が大幅に加速されました。







メインプロジェクトは、Angular上で並行して実行され続け、サポートにますます時間がかかりました。 既成のコードをそのまま使用することはできません すでに解決済みの問題を新たに解決し、コンポーネントをゼロから作成する必要がありました。 さらに、プロジェクトのメインバージョンとモバイルバージョンをアダプティブレイアウトを備えた1つのプロジェクトに結合する見通しが出てきました。







はい、 ngReactがありますが、プロジェクトを一種の怪物フランケンシュタインに変えたいという特別な欲求はありませんでした。 そのため、プロジェクトをReactに移行して、開発とサポートを簡素化することが決定されました。







何だった



主なプロジェクト









関連プロジェクトとモバイル版









ほとんどのビジネスロジック(バリデータ、リクエストの送信、ユーティリティなど)は、NPMモジュールの形式でTypescriptに個別に実装されているため、フレームワークに関係なくプロジェクト間でコードを簡単に再利用できます。







ビジネスに取り掛かる



「私はルーチンとリファクタリングが大好きです!」 - 世界の単一の開発者ではない

リファクタリングは最も興味深い活動ではないことに多くの人が同意すると思います。 したがって、このプロセスを部分的に自動化することにしました。







ReactとAngularのコンポーネントを表面的に比較しても、(もちろん、大幅に簡略化された)式を導出できます。







React.Component = Angular Controller + Angular Directive + Angular Template;







だから、 ng2react-builderが判明しました







ng2react-builder



あなたはおそらく、私がモジュールの命名の達人であることを既に認識しているでしょう。 まあ、それについてではなく...







モジュールでできること







ドキュメントの 例と、テストケースのコンポーネントのさらに良いを見るのが最善です。







モジュールとコントローラーをモジュールにフィードすることができます(ディレクティブはまだ飛行中です)。出力は、JSXマークアップを含むアセンブルされたReactコンポーネント(React.PureComponentまたはReact.Component)になります。







コントローラーがなければ、単純なステートレスコンポーネント(React.StatelessComponent)を簡単にアセンブルできます。







ng2react-builderすべてのAngular式を有効なJS / JSX構成に変換しようとします:









 <!--  --> <div> <span ng-repeat="item in list as | limitTo:5 as results">{{item.name}}</span> </div> <!--  --> <div> {results.slice(0, 5).map((item, index) => { return <span key={`child-${ index }`}>{item.name}</span> })} </div>
      
      







 <!--  --> <a ng-click="$event.preventDefault(); selectItem(item)">{{item.name}}</a> <my-icon="calendar"><my-icon/>
      
      





 //    ng2rect-builder' directivesToTags: { 'my-icon': { tagName: 'MyReactIcon', valueProp: 'type' } }
      
      





 <!--  --> <a onClick={(event) => { event.preventDefault(); selectItem(item); }}> {item.name} </a> <MyReactIcon type="calendar"/>
      
      







もう1つの特に便利なことは、ディレクティブをJS関数呼び出しに変換する機能です(属性として指定されたディレクティブのみがサポートされるようになりました)。







 <!--  --> <span my-directive="some.value"></span>
      
      





 //    ng2rect-builder' directivesToTextNodes: { myDirective: { callee: 'myFunc', calleeArguments: ['arg1'] } }
      
      





 <!--  --> <span>{myFunc(arg1, 'some.value')}</span>
      
      





仕組み









TypescriptコンパイラAPIを使用する理由







  1. コントローラーはTypeScriptで記述できます
  2. 生成されたStateおよびPropsインターフェイスを使用して、TypeScriptでReactコンポーネントを取得します。


奇跡はありません



ああ。 試しなかったように







上記で書いたように、ファイルを取得して手動でリファクタリングを続行する必要がありますが、このモジュールは、特にAngularテンプレートをJSXに変換する際に、日常のタスクに多くの時間を節約しました。







何になった





今後の予定





私はあなたがそれを楽しんでいることを願っています、そして私は誰かがリファクタリングプロセスの時間を節約するのを手伝いました;)








All Articles