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

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

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

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

TypeScript

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

Q&A

解決済

1回答

3598閲覧

「Type '{}' has no call signatures.」を解決したい

like_any_other

総合スコア1

Vue.js

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

TypeScript

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

0グッド

0クリップ

投稿2023/08/02 02:47

実現したいこと

  • 「Vue: This expression is not callable. Type '{}' has no call signatures.」のエラーが出ないようにする

前提

vue3.xでTypeScriptの勉強をしています。
main.tsにてdayjsをインポートして、provideし、別のvueコンポーネントでinjectして使用する際に、
下記のエラーメッセージが表示されました。

発生している問題・エラーメッセージ

Vue: This expression is not callable. Type '{}' has no call signatures.

該当のソースコード

main.ts

1import { createApp } from 'vue' 2import App from './App.vue' 3import router from '@/router/' 4import store from '@/store/' 5 6import dayjs from 'dayjs' 7import 'dayjs/locale/ja' 8dayjs.locale('ja') 9 10const app = createApp(App) 11app.use(store) 12app.use(router) 13app.provide('dayjs', dayjs) 14app.mount('#app') 15

Day.vue

1<template></template> 2<script setup lang="ts"> 3import { ref, inject } from 'vue' 4const dayjs = inject('dayjs') 5const currentTime = ref('') 6 7const bbb = () => { 8 currentTime.value = dayjs().format('YYYY') 9} 10</script>

試したこと

const dayjs = inject('dayjs', null)

にすることで、エラーを回避することはできましたが、とりあえずの対策でしかないような気がします。
根本解決するにはどうしたらよいでしょうか。

また、Day.vueにて、下記のように、型を指定しても、
「Vue: This expression is not callable. Type '{Dayjs}' has no call signatures.」
が発生しました。

import { Dayjs } from 'dayjs' const dayjs = inject<Dayjs>('dayjs')

補足情報(FW/ツールのバージョンなど)

"dayjs": "^1.11.9"
"vue": "^3.3.4"
"typescript": "~5.1.6"

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

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

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

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

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

guest

回答1

0

ベストアンサー

SPAでいきなり依存関係にある変数を注入しているからです。なのでdayjsは初期値が決まっていない状態で、provideから受け取った値に対し、
this expression is not callable. Type '{}' has no call signatures.*
(型宣言してねえから、この式は呼び出せない!)
って怒ってるのです。

なので、公式マニュアルにもある通り、初期値を設定しておけば、いちおうは問題なく通ります。
const dayjs = inject('dayjs', null)

https://ja.vuejs.org/guide/components/provide-inject.html#provide

ちなみに、型を宣言しようとしてエラーになった件ですが

import {Dayjs } from 'Day.js' //これだとDay.jsの中にDayjsと定義された定義変数のオブジェクトが存在しているという前提になる

Dayjsが本当に型を宣言しているのかどうか確認してみてください。どうも別のものを指している気がします。

https://vuejs.org/guide/typescript/composition-api.html#typing-provide-inject

投稿2023/08/03 01:20

編集2023/08/03 01:35
FKM

総合スコア3660

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

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

like_any_other

2023/08/06 23:39

回答ありがとうございます。 import { Dayjs } from のDayjsを調べてみたところ、見る限りでは型定義オブジェクトっぽかったのですが、 エラーが発生するので、初期値をnullで設定するようにしました。 const dayjs = inject('dayjs', null) ご丁寧な回答、ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問