Contents
前提資料
別のWebサービスを作成しているのですがそちらでVue.jsを使用してます。そちらでOfficeアドインが作れるとのこと。こちらのMS公式を参考にしながらやってみました。(Vue.jsとはJavascriptのフレームワークです。)
data:image/s3,"s3://crabby-images/04473/04473c19c7818882148cb122e239b55b7e214893" alt=""
Vueについては以下参照
Vueとその他のフレームワークとの比較については以下。だいぶ人気ありかと。
data:image/s3,"s3://crabby-images/a81a0/a81a0b29745c447e0e783faeb2505bd10577cc9e" alt=""
概略
最初に正直な感想を書いておきます。他のフレームワークを適用した場合と比べてちょっとプロジェクト作成の作業が長くなるので、webpackを使用して、何とかデバッグ環境だけでもうまいこといかんかな。凄いひとにお願いしたいなぁ。JSについては詳しくないので。他のフレームワークの方が開発環境的には進んでおります。(まだ一昔前の形のままかも)
①vue/cliインストールとvueアプリの作成 (vue create)
②vueアプリ内でのマニフェスト関係プロジェクト作成(yo office)
③-1 vue.js.configを追加
③-2 コードの追加
③-3 サーバの起動確認 (npm run serve)
④サイドロードの手順
⑤デバッグ (Vscodeの拡張機能でのデバッグ実行できない)
vue/cliインストールとvueアプリの作成
以下のURLと見比べながら進んでください。
data:image/s3,"s3://crabby-images/04473/04473c19c7818882148cb122e239b55b7e214893" alt=""
まずはnpmが入っていたかを確認してください。
data:image/s3,"s3://crabby-images/9ac2b/9ac2bd6586e1da54b5e70424c246d562020ca5bc" alt=""
npm install -g @vue/cli でグローバルにインストールを行います。
data:image/s3,"s3://crabby-images/6baba/6babaf16a7a994e7b9435fe711b73692146e7d33" alt=""
下記のようになりました。インストールが完了。
data:image/s3,"s3://crabby-images/2c9e5/2c9e564d146dddd28a627343c8b9f2078d4f46f2" alt=""
「vue create my-add-in-vue」と入力。MS公式では、「my-add-in」で作成されてます。
data:image/s3,"s3://crabby-images/f0772/f07724f609ca879f359707322703bacbf0142697" alt=""
矢印キーでDefault (Vue3)を選択。
data:image/s3,"s3://crabby-images/cfe50/cfe50715b3229b244b1e9570b03a0d234975b459" alt=""
勝手に実行が進みます。
data:image/s3,"s3://crabby-images/7f8cd/7f8cdceb4a8465b1dbd6867fe06073d8bb98c1a9" alt=""
vueアプリ(プロジェクトフォルダ)の作成が完了しました。
data:image/s3,"s3://crabby-images/57f09/57f0981fe423709e3c468aa94a4b011e609b11b9" alt=""
この段階でのプロジェクトのフォルダ構成はこのようになっています。
data:image/s3,"s3://crabby-images/4b478/4b4781097153e0d5c6830b9afd6062f1626a599e" alt=""
vueアプリ内でのマニフェスト関係プロジェクト作成(yo office)
作成したプロジェクトフォルダに移動して、そのフォルダ内で、yo officeを実行。
data:image/s3,"s3://crabby-images/0f9a8/0f9a8c0bc5b31360dfa46b33bf15313ebcf9f0ee" alt=""
yoおじさんがでてきました。
data:image/s3,"s3://crabby-images/ba7f1/ba7f162a1921fa985ba837946edc87f118968511" alt=""
「Office Add-in project containing the manifest only」を矢印キーで選択
data:image/s3,"s3://crabby-images/b54f5/b54f57b1d532fc3a539a16c56e580547fd91078a" alt=""
「My-Office-Add-in-v」としました。MS公式では「My Office Add-in」で作成。
data:image/s3,"s3://crabby-images/a4c94/a4c9406314b429e0e0e91044542ea5a80c83360d" alt=""
Excelを選択
data:image/s3,"s3://crabby-images/c3dbf/c3dbfedccb41d0615aea1d1f023ce0c9f612866e" alt=""
作成完了。
data:image/s3,"s3://crabby-images/0cef6/0cef66cd4c73591349234e6aea8fa32b97137579" alt=""
「my-add-in-vue」の中に「My-Office-Add-in-v」が作成されています。
data:image/s3,"s3://crabby-images/0cb5c/0cb5c9b591556261d27b9cc9e3f70537bcc2bb7b" alt=""
「My-Office-Add-in-v」のフォルダ構成はこのような感じです。
data:image/s3,"s3://crabby-images/841af/841af1e9e1a3b7dbe5853b56ba739e775ccefa38" alt=""
vue.config.jsを追加
MS公式の指示に従って、vue.config.jsを追加します。
data:image/s3,"s3://crabby-images/04473/04473c19c7818882148cb122e239b55b7e214893" alt=""
新しいテキストドキュメントを追加。
data:image/s3,"s3://crabby-images/f62e8/f62e8d7799a33add24f4611b9af08ddcf947c2b9" alt=""
vue.config.jsに名前を変更します。(拡張子も。)
data:image/s3,"s3://crabby-images/924c3/924c397017d7f214f2792528b4455a3e0926d9b4" alt=""
VS Codeを同フォルダで起動。
data:image/s3,"s3://crabby-images/d574e/d574e446ec63fe2186c2202e3a497081fd1d174c" alt=""
VS Codeで、vue.config.jsをクリック。
data:image/s3,"s3://crabby-images/1c0d6/1c0d6eda40c118d99369a4ef240d96c0e19e5274" alt=""
MS公式からコードをコピペして保存してください。
data:image/s3,"s3://crabby-images/f87d5/f87d5b9088955843177f0316788bdbcc429b9ed7" alt=""
コードの追加と変更
data:image/s3,"s3://crabby-images/04473/04473c19c7818882148cb122e239b55b7e214893" alt=""
index.html
MS公式の「アプリを更新する」の指示に従って、「my-add-in-vue¥public」の中の、index.htmlをクリックします。
data:image/s3,"s3://crabby-images/53793/537938c12be04697511171904913f26747fd3dff" alt=""
data:image/s3,"s3://crabby-images/ecf00/ecf008a28082a0c484b6829070a72541cfc7ab2a" alt=""
<script>~</script>の一行を、</head>と<body>の間に追加
data:image/s3,"s3://crabby-images/d32b2/d32b231bdc0d27cd83bf3ee8c12a5c7f994e3279" alt=""
manifest.xml
data:image/s3,"s3://crabby-images/32866/3286664e97fa53f9a8e0c43cc9475fa4234058f5" alt=""
変更前 manifest.xml
data:image/s3,"s3://crabby-images/c3514/c351498c86bb2f3216227ec3334be3727375dcce" alt=""
変更後 manifest.xml (129行目)
data:image/s3,"s3://crabby-images/14755/147552decd7f589f9131af262537779fcce0e0bb" alt=""
main.js
data:image/s3,"s3://crabby-images/51774/51774e3384a64ffe8e8daf0dc48c496075bb792f" alt=""
data:image/s3,"s3://crabby-images/03969/03969b72e7272a5621d1ecb9746187ef88df6bb8" alt=""
App.vue
data:image/s3,"s3://crabby-images/d7544/d75444c2e8db5b220508102dde4f6d46f00028ce" alt=""
data:image/s3,"s3://crabby-images/5bbc7/5bbc7d6b334f9e2f0611d81dc3834666831774b1" alt=""
サーバの起動確認 (npm run serve)
npm run serveと入力して、サーバを起動
data:image/s3,"s3://crabby-images/84319/843193b762ce9713ee79eb83d209faef34b350db" alt=""
ブラウザに「https://localhost:3000」を入れると、以下のようなページが表示されていればOKです。
data:image/s3,"s3://crabby-images/f8b59/f8b59ae84a9a0536cd56a225a4f1bdcd01b3e574" alt=""
サーバの終わり方は「Ctrl+C」を押して、バッチジョブを終了しますか?で「Y」を入力してください。
data:image/s3,"s3://crabby-images/6650e/6650e2445998c4181db2bc318f5156e4a81a7180" alt=""
サイドロードの手順
編集中
デバッグ
編集中
感想
長い。。本気でやるなら,開発環境整えてからかな。。息切れしそうです。
興味本位で書いたけど、誰が読むんだろうか??
githubのissueも有った。ただし方向性も全く分からない(泣)