Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Using Class Components without @Options annotation leads to "Transform failed" #2787

Closed
6 tasks done
cypressious opened this issue Mar 30, 2021 · 2 comments · Fixed by #2933
Closed
6 tasks done

Using Class Components without @Options annotation leads to "Transform failed" #2787

cypressious opened this issue Mar 30, 2021 · 2 comments · Fixed by #2933

Comments

@cypressious
Copy link

Describe the bug

According to vuejs/vue-class-component#406, when using Class Components with Vue 3, the @Options annotation is optional.

However, when leaving the annotation out, vite throws the following error:

[plugin:vite:vue] Transform failed with 1 error:
C:/Users/krakhman/Repos/vue3-playground/src/components/ClassComponent2.vue:2:41: error: Expected ";" but found "class"

C:/Users/krakhman/Repos/vue3-playground/src/components/ClassComponent2.vue:2:41

Expected ";" but found "class"
1  |  
2  |  import { Vue } from "vue-class-component"class ClassComponent extends Vue {
   |                                           ^
3  |    counter = 0
4  |  }

    at failureErrorWithLog (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:1224:15)
    at C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:1072:33
    at C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:568:9
    at handleIncomingPacket (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:657:9)
    at Socket.readFromStdout (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:535:7)
    at Socket.emit (node:events:378:20)
    at addChunk (node:internal/streams/readable:313:12)
    at readableAddChunk (node:internal/streams/readable:288:9)
    at Socket.Readable.push (node:internal/streams/readable:227:10)
    at Pipe.onStreamRead (node:internal/stream_base_commons:190:23

Reproduction

<template>
  <div>
    {{ counter }}
    <button @click="counter++">Increment</button>
  </div>
</template>

<script lang="ts">
import { Vue } from "vue-class-component";

export default class ClassComponent extends Vue {
  counter = 0
}
</script>

System Info

Output of npx envinfo --system --npmPackages vite,@vitejs/plugin-vue --binaries --browsers:

  System:
    OS: Windows 10 10.0.19042
    CPU: (12) x64 AMD Ryzen 5 PRO 4650U with Radeon Graphics
    Memory: 13.93 GB / 31.23 GB
  Binaries:
    Node: 15.10.0 - C:\Program Files\nodejs\node.EXE
    Yarn: 1.22.5 - C:\Program Files (x86)\Yarn\bin\yarn.CMD
    npm: 7.6.1 - C:\Program Files\nodejs\npm.CMD
  Browsers:
    Edge: Spartan (44.19041.423.0), Chromium (89.0.774.63)
    Internet Explorer: 11.0.19041.1

Used package manager: yarn

Logs

16:02:50 [vite] Internal server error: Transform failed with 1 error:
C:/Users/krakhman/Repos/vue3-playground/src/components/ClassComponent2.vue:2:41: error: Expected ";" but found "class"
  Plugin: vite:vue
  File: C:/Users/krakhman/Repos/vue3-playground/src/components/ClassComponent2.vue
  
  Expected ";" but found "class"
  1  |  
  2  |  import { Vue } from "vue-class-component"class ClassComponent extends Vue {
     |                                           ^
  3  |    counter = 0
  4  |  }
  
      at failureErrorWithLog (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:1224:15)
      at C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:1072:33
      at C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:568:9
      at handleIncomingPacket (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:657:9)
      at Socket.readFromStdout (C:\Users\krakhman\Repos\vue3-playground\node_modules\esbuild\lib\main.js:535:7)
      at Socket.emit (node:events:378:20)
      at addChunk (node:internal/streams/readable:313:12)
      at readableAddChunk (node:internal/streams/readable:288:9)
      at Socket.Readable.push (node:internal/streams/readable:227:10)
      at Pipe.onStreamRead (node:internal/stream_base_commons:190:23)

Before submitting the issue, please make sure you do the following

@patak-dev
Copy link
Member

@cypressious would you try to reproduce this without Vite? I think this is an issue with the Vue SFC compiler and it should be reported in the vue-next repo.

@cypressious
Copy link
Author

@patak-js I just tried and it works with vue-cli.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants