$30 off During Our Annual Pro Sale. View Details »
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Microsoft 365 開発をはじめる人のための React 超入門 / Super in...
Search
Takashi Shinohara
June 26, 2021
Programming
0
1.2k
Microsoft 365 開発をはじめる人のための React 超入門 / Super introduction to react for those starting Microsoft 365 development
.NET ラボ勉強会 2021 年 6 月 (
https://dotnetlab.connpass.com/event/214208
) に登壇したときのスライドです。
Takashi Shinohara
June 26, 2021
Tweet
Share
More Decks by Takashi Shinohara
See All by Takashi Shinohara
Microsoft 365 の認証と承認を理解する / Understanding Microsoft 365 Authentication and Authorization
karamem0
0
140
Power Automate のパフォーマンス改善レシピ / Power Automate Performance Improvement Recipes
karamem0
0
400
どっちの API SHOW?SharePoint 開発における SharePoint REST API Microsoft Graph API の違い / Which API show? Differences between Microsoft Graph API and SharePoint REST API
karamem0
0
1.7k
Microsoft Ignite 2024 最新情報!Microsoft 365 Agents SDK 概要 / Microsoft Ignite 2024 latest news Microsoft 365 Agents SDK overview
karamem0
0
540
徹底解説!Microsoft 365 Copilot の拡張機能 / Complete guide to Microsoft 365 Copilot extensions
karamem0
1
4.3k
Microsoft Search の Graph コネクタ ハンズオン / Handson for Graph Connector of Microsoft Search
karamem0
0
210
いまだから「検索」を語ろう! SharePoint FAST Search から Microsoft Search セマンティックインデックスまで / Let's talk about search now
karamem0
4
1.7k
徹底解説!Power Platform 導入の成功事例から見る DX 推進のコツ / Tips for DX promotion from Power Platform case studies
karamem0
0
5.4k
どうする Power Pages?Web 開発者からみる Power Pages / How to deal with Power Pages
karamem0
0
1.4k
Other Decks in Programming
See All in Programming
LLM Çağında Backend Olmak: 10 Milyon Prompt'u Milisaniyede Sorgulamak
selcukusta
0
140
[AtCoder Conference 2025] LLMを使った業務AHCの上⼿な解き⽅
terryu16
6
790
perlをWebAssembly上で動かすと何が嬉しいの??? / Where does Perl-on-Wasm actually make sense?
mackee
0
170
LLMで複雑な検索条件アセットから脱却する!! 生成的検索インタフェースの設計論
po3rin
4
980
AI時代を生き抜く 新卒エンジニアの生きる道
coconala_engineer
1
440
AIの誤りが許されない業務システムにおいて“信頼されるAI” を目指す / building-trusted-ai-systems
yuya4
6
4k
TestingOsaka6_Ozono
o3
0
180
Graviton と Nitro と私
maroon1st
0
140
クラウドに依存しないS3を使った開発術
simesaba80
0
170
脳の「省エネモード」をデバッグする ~System 1(直感)と System 2(論理)の切り替え~
panda728
PRO
0
120
AtCoder Conference 2025「LLM時代のAHC」
imjk
2
590
認証・認可の基本を学ぼう後編
kouyuume
0
250
Featured
See All Featured
CSS Pre-Processors: Stylus, Less & Sass
bermonpainter
359
30k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.6k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
61
41k
Mozcon NYC 2025: Stop Losing SEO Traffic
samtorres
0
94
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
132
19k
Principles of Awesome APIs and How to Build Them.
keavy
127
17k
Stewardship and Sustainability of Urban and Community Forests
pwiseman
0
73
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
0
3.4k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
70
XXLCSS - How to scale CSS and keep your sanity
sugarenia
249
1.3M
Product Roadmaps are Hard
iamctodd
PRO
55
12k
Transcript
Microsoft 365 開発をはじめる人のための React 超入門 .NET ラボ 勉強会 2021 年
6 月 2021/6/26 Microsoft MVP for Office Development 篠原 敬志 (@karamem0)
Japan M365 Dev User Group にご参加ください Facebook グループ https://www.facebook.com/groups/jpm365dev connpass
https://jpm365dev.connpass.com
このセッションのゴール モダンな Microsoft 365 開発 に乗り遅れた をこれからはじめる方に、React をはじめるべき理由 と、超基本的な React
の仕組みについて理解します。 フロントエンドなんて 自分には関係ないよね JavaScript? jQuery しかわからん
モダンな Microsoft 365 開発
Microsoft 365 開発のスコープ Microsoft Graph SharePoint Framework Microsoft Teams Office
Add-in Microsoft ID Platform Adaptive Cards
"モダン開発" とは レガシー 一方向 密結合 同期的 SOAP XML オンプレミス シングル
プラットフォーム シングル デバイス 手動テスト ウォーターフォール モダン 双方向 疎結合 非同期的 REST JSON クラウド マルチ プラットフォーム マルチ デバイス 自動テスト アジャイル
Microsoft 365 開発のモダン化 (SharePoint) ファーム ソリューション サーバー サイド ASP.NET Webフォーム
SSOM オンプレミス SharePoint アドイン クライアント サイド ASPX + JavaScript JSOM オンプレミス/クラウド SharePoint Framework クライアント サイド HTML5 + TypeScript REST API オンプレミス/クラウド
Microsoft 365 開発のモダン化 (Office) VBA ファイル形式 Visual Basic オンプレミス VSTO
インストール形式 .NET Framework オンプレミス Office アドイン インストール形式 HTML5 + TypeScript オンプレミス/クラウド Office スクリプト ファイル形式 TypeScript クラウド
Microsoft 365 開発のトレンド TypeScript AltJS のデファクト スタンダード マイクロソフトが開発 静的型付けが可能 npm
Node.js に含まれる JavaScript のパッケージ マネージャー サーバーサイド/クライアントサイドに関係なく使われる SPA シングル ページ アプリケーション 動的に HTML (DOM) を書き換えることでユーザー体験を向上させる
モダンな JavaScript フレームワーク
JavaScript フレームワークのトレンド (すべての国) https://trends.google.co.jp/trends/explore?date=2014-06-19%202021-06-18&q=%2Fm%2F012l1vxv,%2Fg%2F11c6w0ddw9,%2Fg%2F11c0vmgx5d,%2Fm%2F0268gyp
JavaScript フレームワークのトレンド (日本) https://trends.google.co.jp/trends/explore?date=2014-06-19%202021-06-18&geo=JP&q=%2Fm%2F012l1vxv,%2Fg%2F11c6w0ddw9,%2Fg%2F11c0vmgx5d,%2Fm%2F0268gyp
Why React? (※個人の感想です) 利用者が多い 最近は特に人気が出てきている 比較的シンプル Angular は全部入っているので逆にちょっと重い 安定性 Facebook
とコミュニティによって開発されている ネイティブへの対応 React を習得すれば React Native で Windows アプリも作れるようになる 習得の容易さ XAML 開発者であればとっつきやすい
Fluent UI Fluent Design System の実装として提供される UI コンポーネント群 もともと Office
UI Fabric と呼ばれていた React または Web Components 向けに提供 Office 向けと Microsoft Teams 向けのバージョンが存在する (ややこしい)
jQuery と React を比べてみる
アプリケーションの構造 jQuery React HTML と JavaScript は別のファイルに書く HTML の中に JavaScript
を書く JavaScript (JSX) の中に HTML を書く HTML を JavaScript の変数として扱うことが できる HTML JS HTML JS <script> ... </script> JSX HTML <div> ... </div>
DOM の操作 jQuery React CSS セレクターにより DOM を直接操作する 仮想的な DOM
(インメモリのオブジェクト) か ら React が差分検出処理をして実際の DOM に同期する 実際の DOM は操作しない (useRef) jQuery DOM JSX 仮想 DOM DOM 差分検出
データ バインディング jQuery React そんなものはない😡 あるいは knockout.js 変数 (props や
state) の値が変更されると 自動的に再レンダリングされる $('#myinput').val('jQuery'); <input id="myInput" type="text" value="" /> const [value, setValue] = useState<string>(); useEffect(() => { setValue('jQuery'); }, []); return ( <input type="text" value={value} /> );
コンポーネントの利用 jQuery React 命令的 宣言的 <script src="./jquery.min.js"></script> <script src="./jquery-ui.min.js"></script> <script>
$(function () { $('#datepicker').datepicker(); }); </script> <div id="datepicker"></div> import { DatePicker } from '@fluentui/react- northstar'; ReactDOM.render( <DatePicker />, document.getElementById('root') );
React の基本
コンポーネント 任意の入力 (props) を受け取り UI 要素を返す再利用可能な部品 感覚的には WPF や UWP
のコントロールに近い コンポーネントが別のコンポーネントを呼び出すことで構造化することができる クラス コンポーネントと関数コンポーネントがある props は読み取り専用なので書き換えられない 親のコンポーネントで props の値が変更されると子のコンポーネントは再レンダリングされる
ライフサイクル コンポーネントの内部の状態は state によって管理される useState により state であることを宣言する 値を変更すると変更が伝播し必要に応じて再レンダリングが発生する useEffect
を使うことで state の変更を検知できる
コンテキスト props のバケツ リレーを避けるための仕組み グローバル変数的にあらゆるところから呼び出しができる 便利だが影響が大きいので多用は厳禁
カスタム フック useEffect を含むビジネス ロジックをコンポーネントから切り離すための仕組み これがないとコンポーネントが Fat になるので積極的に使うべき タイマーや API
の呼び出しをカスタム フックにまとめることが多い
テスト Jest および React Testing Library により単体テストが可能 UI テスト DOM
が正しく生成されることを確認するためのテスト イベントを発生させることも可能 スナップショット テスト UI の変更を検知するためのテスト
文章じゃわからないので… デモ
まとめ Microsoft 365 開発の時流は JavaScript その中でも React を使った開発がおすすめ React コワクナイヨ
ご清聴ありがとうございました