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

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

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

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

Q&A

解決済

1回答

4441閲覧

[vue.js] vueコンポーネントでv-ifを使って要素を切り替えたい

yu-smc

総合スコア610

Vue.js

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

0グッド

0クリップ

投稿2018/06/07 10:14

前提・やりたいこと

vueコンポーネントでv-ifを使って、IEとそれ以外のときに要素を切り替えたいです。

以下コードです。

lang

1Vue.component('waypoint-warp', { 2 template: ` 3 <div class="js-lazy-target" v-bind:class="{'animated fadeIn' : isInView}" style="opacity:100" v-if="isIE == 'true'"> 4 <v-waypoint @waypoint="waypointHandler" ref="waypointEvent"></v-waypoint> 5 <slot></slot> 6 <div id="isIE">{{val.isIE}}</div> 7 </div> 8 <div class="js-lazy-target" v-bind:class="{'animated fadeInUp' : isInView}" style="opacity:0" v-if="isIE == 'false'"> 9 <v-waypoint @waypoint="waypointHandler" ref="waypointEvent"></v-waypoint> 10 <slot></slot> 11 <div id="isIE">{{val.isIE}}</div> 12 </div> 13 `, 14 data() { 15 return { 16 isInView: false, 17 isIE: 'false' 18 }; 19 }, 20 computed: { 21 isIE: window.onload = function(){ 22 if(navigator.userAgent.indexOf("Trident") != -1){ 23 document.getElementById('isIE').innerText = 'true' 24 } else { 25 document.getElementById('isIE').innerText = 'false' 26 } 27 } 28 }, 29 methods: { 30 waypointHandler(direction, going) { 31 if (going == "in") { 32 this.isInView = true; 33 this.$refs.waypointEvent.$destroy() 34 } 35 }, 36 }, 37});

isIEの文字列を変換するところまでは動くのですが、完全のv-ifによる分岐が動きません。いろいろ調べているのですが、この構造の場合どのように書けばいいかわからず、こちらで質問させていただいた次第です。

テンプレートは仮のものなので気にしないでください。

どうぞよろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

HTMLのv-ifですがこのような感じでよいかと思います。

html

1<div v-if="isIE"> 2 ... 3</div 4<div v-else> 5 ... 6</div>

script部分はuser agentは途中で変化もしないと思いますので、インスタンス生成時に一度実行すれば良いと思います。

javascript

1{ 2 data() { 3 return { 4 isIE: false 5 } 6 }, 7 created() { 8 this.isIE = navigator.userAgent.indexOf("Trident") !== -1 9 } 10}

回答になっておりましたら幸いです。
※vueの書き方について記載致しましたが、IEの判定ロジックが正しいか等は特に確認しておりません

投稿2018/06/07 10:26

isoppp

総合スコア102

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

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

yu-smc

2018/06/08 01:31

ご回答ありがとうございます! 上記のように記述したところ、正常に動作しました!! createdを使うという考えに至らず、反省しさらなる学習意欲につなげるきっかけになりました。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問