質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

プラグイン

プラグイン(plug-in)は、ソフトウェアアプリケーションの機能拡張の為に開発された、一組のソフトウェアコンポーネントのことを指します。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Q&A

解決済

1回答

1526閲覧

Vueプラグイン内の非同期処理の完了を、コンポーネントに通知したい

tara-tail

総合スコア32

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

プラグイン

プラグイン(plug-in)は、ソフトウェアアプリケーションの機能拡張の為に開発された、一組のソフトウェアコンポーネントのことを指します。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

0グッド

0クリップ

投稿2019/12/11 08:27

編集2019/12/16 03:57

###前提
cordovaの「ファイル操作プラグイン」をvueのプラグインで使用したいと考え、そのプラグインを自作しています。
fileSystemdirectoryEntryに読み込まれた後の処理(非同期)については、単一コンポーネント内(vueファイル)で実行したいと考えています。
現在、以下の様にfileSystemの読み込みが完了したことを、vueコンポーネントファイルのウォッチャでを監視しています。

js

1// plugin.js 2import Vue from 'vue' 3 4const file = { 5 install: function (Vue) { 6 let vm = new Vue({ 7 data: { 8 directoryEntry: null 9 } 10 }) 11 // ファイルシステム初期化 12 function initFileSystem() { 13 window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, setDirecrotyEntry) 14 } 15 16 function setDirecrotyEntry(fileSystem) { 17 store.directoryEntry = fileSystem.root 18 } 19 20 // ファイルシステムの読み込み 21 document.addEventListener('deviceready', initFileSystem, false) 22 Vue.prototype.$file = vm.$data 23 } 24} 25 26Vue.use(file)

vue

1// xxx.vue 2<script> 3 export default { 4 watch: { 5 '$file.directoryEntry': function() { 6 alert('successfull') 7 } 8 } 9 } 10</script>

###実現したいこと
他のアプリにプラグインを使いまわすため、上記の様な非同期の処理をプラグイン内で完結させ、その完了を待って各コンポーネントで処理を実行させたいと思っています。そのような方法があれば教えていただけないでしょうか?
###試したこと
プラグイン内のVueインスタンスにウォッチャーを設定できますが、それを各vueコンポーネントで取得する方法がわかりませんでした。
Vuexのストアを使用する手順も考えましたが、やはりファイルが別れてしまい、他のアプリに流用するときに煩雑になってしまうことを懸念しています。

js

1// plugin.js 2const file = { 3 install: function (Vue) { 4 let vm = new Vue({ 5 data: { 6 directoryEntry: null 7 }, 8 watch: { 9 'this.directoryEntry': function() { 10 alert('successfull') 11 } 12 } 13 }) 14 } 15} 16 17Vue.use(file)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

プラグインでVueインスタンスの「vm」に続けて、「$watch」を記載すれば、プラグイン内でウォッチャできることが分かりました。
このように、Vueインスタンスを使用して、他のプラグインのインスタンスメソッドを使用したり、storeを使用したりすることができる様になりました。
気を付けたいのは、ウォッチャで監視するプロパティは、「vm.directoryEntry」とするのではなく、インスタンスプロパティ「$file.directoryEntry」を指定することです。これは、どうしてだか分かりません。

js

1import Vue from 'vue' 2import store from '../store.js' // ストアを使用するときは、ストアファイルを読み込む 3 4const file = { 5 install: function (Vue) { 6 let vm = new Vue({ 7 data: { 8 directoryEntry: null 9 }, 10 store // 読み込んだストアはここに登録する。 11 }) 12 // ファイルシステム初期化 13 function initFileSystem() { 14 window.requestFileSystem(LocalFileSystem.PERSISTENT, 0, setDirecrotyEntry) 15 } 16 17 function setDirecrotyEntry(fileSystem) { 18 vm.directoryEntry = fileSystem.root 19 } 20 // Promiseと$watchを組み合わせてインスタンスメソッドを作成すれば、 21 // 使い回すときに煩雑にならずにすみます。 22 Vue.prototype.$init = function() { 23 return new Promise(function(resolve, reject) { 24 vm.$watch('$file.directoryEntry', function() { 25 resolve() 26 }) 27 }) 28 } 29 Vue.prototype.$file = vm.$data 30 } 31} 32 33Vue.use(file)

投稿2019/12/16 04:30

編集2020/04/02 10:35
tara-tail

総合スコア32

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問