[解決済み] VueのsetTimeoutに相当するもの?
質問
LaravelとVueでショッピングカートシステムを作っています。商品をカゴに入れると、v-ifで監視しているVueの変数をトグルして確認メッセージを表示しています。
<div class="alert alert-success" v-if="basketAddSuccess" transition="expand">Added to the basket</div>
そして、JS。
addToBasket: function(){
item = this.product;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
}
(そして、はい、私はまもなくこれを then-catch で追加する予定です)。
これは問題なく動作し、メッセージは表示されます。しかし、ある時間、例えば数秒後にメッセージが再び消えるようにしたいのです。Vueでこれを行うにはどうしたらよいでしょうか?私は試してみました
setTimeOut
しかし、Vueはそれが未定義であると言って、それを好まないようです。
EDIT: スペルを間違えていました
setTimeout
馬鹿の一つ覚えのように しかし、やはりうまくいきません。
私の関数は今
addToBasket: function(){
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
setTimeout(function(){
this.basketAddSuccess = false;
}, 2000);
}
解決方法は?
アロー機能
この問題を解決する最も簡単で良い方法は、矢印関数を使用することです。
() => {}
:
addToBasket() {
var item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
// now 'this' is referencing the Vue object and not the 'setTimeout' scope
setTimeout(() => this.basketAddSuccess = false, 2000);
}
このように動作するのは
this
の矢印関数は
にバインドされます。
this
その
スコープを囲む
- Vueでは、それが親コンポーネント/囲い込みコンポーネントです。によって呼び出される従来の関数の内部では
setTimeout
が、しかし。
this
は
window
オブジェクト
(にアクセスしようとしたときにエラーが発生したのはそのためです。
this.basketAddSuccess
を使用します)。
引数の受け渡し
別の方法として
this
を通して関数への引数として使用します。
setTimeout
のプロトタイプ
を使用して、その
setTimeout(callback, delay, arg1, arg2, ...)
のフォームを使用します。
addToBasket() {
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
//Add scope argument to func, pass this after delay in setTimeout
setTimeout(function(scope) {
scope.basketAddSuccess = false;
}, 2000, this);
}
(ただし、argを渡す構文はIE9以下と互換性がないことに注意が必要です)。
ローカル変数
もう一つ
可能
しかし、あまり雄弁でなく、推奨されない方法は
this
の外側の変数に
setTimeout
:
addToBasket() {
item = this.photo;
this.$http.post('/api/buy/addToBasket', item);
this.basketAddSuccess = true;
//Declare self, which is accessible inside setTimeout func
var self = this;
setTimeout(function() {
self.basketAddSuccess = false;
}, 2000);
}
しかし、arrow関数を使えば、この余分な変数は必要なくなるので、何か他の妨げがない限り、本当に使うべきです。
関連
-
[解決済み】JavaScriptのgetElementByNameが機能しない
-
[解決済み】'useState' が定義されていない no-undef React
-
[解決済み】Uncaught TypeError: 未定義のプロパティ 'msie' を読み取れない - jQuery tools
-
[解決済み】Vueが定義されていない
-
[解決済み] jQueryを使用しない$(document).ready相当
-
[解決済み] printf/String.Formatに相当するJavaScriptの機能
-
[解決済み] jQueryのdocument.createElementと同等?
-
[解決済み] setTimeout(fn, 0)が役に立つことがあるのはなぜですか?
-
[解決済み] setTimeout()コールバックにパラメータを渡すにはどうすればよいですか?
-
[解決済み] setTimeoutかsetIntervalか?
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】NodeJS "ESモジュールをロードするためにインポートを使用する必要があります。"
-
[解決済み】JavaScript "Uncaught TypeError: object is not a function" 連想性の質問
-
[解決済み】「Uncaught TypeError: Chromeで "Illegal invocation "が発生する。
-
[解決済み] React with ES7: Uncaught TypeError: Cannot read property 'state' of undefined [duplicate] (未定義のプロパティ'state'を読み込むことはできません。
-
[解決済み] テスト
-
[解決済み】Reactのeslintエラーはpropsの検証で見つからない
-
[解決済み】Javascript - ERR_CONTENT_LENGTH_MISMATCH
-
[解決済み】React.jsの配列の子要素のユニークキーを理解する
-
[解決済み】'useState' が定義されていない no-undef React
-
[解決済み] Uncaught (in promise) TypeError: フェッチに失敗してCorsエラー