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

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

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

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

Q&A

解決済

1回答

4195閲覧

NuxtをTypeScriptで利用しようとするとCannot find moduleというエラーがでます

Vinoue

総合スコア15

Vue.js

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

0グッド

1クリップ

投稿2019/12/06 17:14

編集2019/12/06 17:23

症状

このページを参考にTypeScript版Nuxtをインストールしました。
コンポーネントをimportする際、以下のように書き、

import { Component, Vue } from 'nuxt-property-decorator' @Component({ components: { Logo: () => import('~/components/Logo') } })

yarn devで実行すると、
VSCodeとコンソールで以下のようなエラーがでます

Cannot find module '~/components/Logo'.Vetur(2307)

元から用意されているLogo.vueが見つからないようで、なぜかエラーがでます。

やってみたこと

NuxtやvuejsのIssueでは、ルートディレクトリにts-shim.d.tsとか、適当な名前のファイルを置き

typescript

1declare module '*.vue' { 2 import Vue from 'vue' 3 export default Vue 4}

Cannot find module (TS2307)

ネットで調べる限り、いずれも似たような方法で解決されているのですが、なぜか自分は解決できませんでした。

その他の情報

pathsについてもちゃんと設定されています。

// tsconfig.json { "compilerOptions": { "target": "esnext", "module": "esnext", "moduleResolution": "node", "lib": ["esnext", "esnext.asynciterable", "dom"], "esModuleInterop": true, "allowJs": true, "sourceMap": true, "strict": true, "noEmit": true, "baseUrl": ".", "paths": { "~/*": ["./*"], "@/*": ["./*"] }, "types": ["@types/node", "@nuxt/types"] }, "exclude": ["node_modules"] }

他に

  • VSCodeの拡張機能のVeturが関係あるかと思い一度アンインストールして、もう一度インストールして再起動などしてみましたが意味ありませんでした
  • Logo.vueは確実にあります。componentsのスペルも間違っていません。
  • ~を@に変えても結果は同じでした。

分かる方どうぞよろしくお願いします。

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

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

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

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

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

guest

回答1

0

自己解決

すいません、解決しました。.vueを入れ忘れておりました。

投稿2019/12/06 18:00

Vinoue

総合スコア15

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問