vueでwindowを使うとエラーになる

vueでwindowを使うとエラーになる:


画面のサイズを取りたい

vueでwindowを使って画面のサイズを取りたい時にハマってしまった

<script> 
export default { 
  computed: { 
    windowSize: () => { 
      return { x: window.innerWidth, y: window.innerHeight } 
    } 
  } 
} 
</script> 
window is not defined


原因

コンポーネントのライフサイクルが関係しており、適切な場所でwindowを使わなければならない

ライフサイクル


解決策

mountedでwindowSizeをセットするように実行

<script> 
  export default { 
    data: () => ({ 
      windowSize: { 
        x: 0, 
        y: 0 
      } 
    }), 
 
    mounted () { 
      this.onResize() 
    }, 
 
    methods: { 
      onResize () { 
        this.windowSize = { x: window.innerWidth, y: window.innerHeight } 
      } 
    } 
  } 
</script> 
問題なくwindowを使うことができた!

コメント

このブログの人気の投稿

投稿時間:2021-06-17 22:08:45 RSSフィード2021-06-17 22:00 分まとめ(2089件)

投稿時間:2021-06-20 02:06:12 RSSフィード2021-06-20 02:00 分まとめ(3871件)

投稿時間:2021-06-17 05:05:34 RSSフィード2021-06-17 05:00 分まとめ(1274件)