メニュー
ブログ更新履歴
コンテンツ更新履歴
リンク
  • rlib-MML WebApp
  • MML (Music Macro Language) をコンパイルし、再生やファイル出力(MP4、標準MIDIファイル)をブラウザ上で行えます。
  • Magome
  • クラウドベースのMIDIシーケンサ
    音楽制作に興味のある方を対象に、スタンドアロンでも使え、ネットならではの面白さも兼ね備えた音楽制作アプリの提供を目指しています。
twitter

VisualStudioでのフロントエンド開発で React が使えるようにインストールします。

技術系備忘録​/TypeScript​/VisualStudioでのフロントエンド開発環境 からの続きで書いてますので、まずはそっちを復習ってもらうとスムーズです。

ココでは React の導入を扱ってますが、他のモジュールについても(型定義ファイル等が提供されているものであれば)ほぼ同じです。

注意事項 anchor.png

  • ココで記載している手順は TypeScript2.0 を前提にしています。そのため、TypeScript2.0 未満の環境だと、そのままでは動きません。
    • TypeScript2.0 から npm 単体で型定義ファイルの取得が出来るようになったようなので、それを利用しています。
      2.0 未満の場合、tsd か typings などを使うことになりますが、それについてはココでは端折ります。
  • VisualStudio2013 では TypeScript2.0 plugin は提供されないっぽいので、今のところ VisualStudio2015 + TypeScript2.0 plugin 縛りの情報です。
  • 今時点の TypeScript2.0 はまだベータ版(RCなのかな?)ですが、そこは気にせず TypeScript 2.0.2 Beta for Visual Studio 2015 という plugin を使っています。
Page Top

手順 anchor.png

Page Top

react.js をインストール anchor.png

プロジェクトのカレントディレクトリをコマンドプロンプトで開きます。

  1. npm で react と react-dom をインストールします。
    > npm install --save react
    > npm install --save react-dom
Page Top

型定義ファイルをインストール anchor.png

プロジェクトのカレントディレクトリをコマンドプロンプトで開きます。

  1. npm @types で react と react-dom の型定義ファイルをインストールします。
    > npm install --save @types/react
    > npm install --save @types/react-dom
  • これで package.json に情報が追記されているので、> npm install で同じ環境が作れます。
  • TypeScript2.0 未満ではこの方法は使えませんので、ご注意下さい。
Page Top

とりあえずサンプルコード anchor.png

  1. プロジェクトのコンテキストメニュー [追加]-[TypeScript JSX ファイル] を選択し、ファイル名 [reacttest.tsx]で作成します。
    • 中身は以下のようにします。
      import * as React from 'react';
      export default class ReactTest extends React.Component<{}, {}>
      {
      	render(){
      		return (
      			<h1>React Test!</h1>
      		);
      	}
      }
  2. app.ts を編集します。
    1. 先頭付近に以下を追記します。
      import * as React from 'react';
      import * as ReactDOM from 'react-dom';
      import ReactTest from "./reacttest";
    2. window.onload = () => { の中に以下を追記します。
      window.onload = () => {
      	・・・
      	ReactDOM.render(
      		React.createElement( ReactTest, {} ),
      		document.getElementById('reacttest')
      	);
      };
  3. index.html を編集します。
    <body>
    	・・・
    	<div id="reacttest"></div>   <!-- 追加 -->
    </body>
  4. 以上で完了です。F5キーを押してブラウザで正しく表示されるか確認して下さい。
Page Top

React 本体は結合させない方法 anchor.png

上記では、自身のコードの他に React.js 本体のコードも結合された巨大な js ファイルが出来上がることになります。
それで問題ない場合も多々あると思いますが、react.js は別ファイルにしておきたいとか、CDN に任せたいとかあると思います。
そういう場合には、webpack の設定で結合対象から react を外すことが可能です。

  1. webpack.config.js を編集し、以下を追記します。
    	externals: {
    		'react': 'React',
    		'react-dom': 'ReactDOM',
    	},
  2. index.html で react.js を明示的に読み込むように編集します。
    	・・・
    	<script src="node_modules/react/dist/react.js"></script>			<!-- 追加 -->
    	<script src="node_modules/react-dom/dist/react-dom.js"></script>	<!-- 追加 -->
    	<script src="bundle.js"></script>
    	・・・
    • ↑のように自身で抱えてもいいですが、世間様のCDNサイトを指定するでももちろんOKです。
  3. 以上で完了です。ビルドして出来上がった bundle.js ファイルが 4KB 程度で収まっていることと、ブラウザで正しく表示されることを確認して下さい。
    ReactTest.png
Page Top

よもやま anchor.png

  • TypeScript2.0 の @types はとても便利です。環境構築の手間がだいぶシンプルになります。
    @types はマイクロソフト様が用意してくれているっぽい(らしい。とどこかのサイトに書いてありました)ので、なんとなく安心です。
  • 現在提供されている React の型定義ファイルのバージョンは v0.14 って書いてあります。一方 React.js は 15.3.x です。このあたりはどこかで追いついてくれるといいなぁと思いました。

Front page   Freeze Diff Backup Copy Rename ReloadPrint View   New Page Page list Search Recent changes   Help   RSS of recent changes (RSS 1.0) RSS of recent changes (RSS 2.0) RSS of recent changes (RSS Atom) Powered by xpWiki
Counter: 6051, today: 1, yesterday: 2
Princeps date: 2016-09-22 (Thu) 19:36:16
Last-modified: 2016-09-22 (Thu) 20:23:03 (JST) (2941d) by takatsuka