-
-
Notifications
You must be signed in to change notification settings - Fork 8.5k
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
@vue/compiler-sfc remove ~/
when handling the assets in template.
#11367
Comments
As a newbee I think while you using '~' means that you are using vite's alias feature.So vite will canvert '~' before vue's compile.Then it's wrong if the link is start with '~' or '~/'.Vue is try to be compatible with it I think.If it's going like this,it will be better to throw a warning maybe? |
Sorry I forgot to mention that I am using alias feature of vite. 😖
On the contrary, vite will transform alias after compiling vue files. You can see the process by the plugin In order:
<img src="@/test.jpg" > was transformed to import _imports_0 from "@/test.jpg";
const _hoisted_1 = /* @__PURE__ */ _createElementVNode(
"img",
{ src: _imports_0 },
null,
-1
/* HOISTED */
);
import _imports_0 from "@/test.jpg"; was transformed to import _imports_0 from "/src/test.jpg?import"; |
I'm misunderstood this issue by using ~ in import.It should only happend in img and other tags.Here is webpack vue loader doc.Maybe compiler-sfc try to do the some. |
That sounds like it make sense. Since you have referred a PR so I do not close the issue by myself. |
* doc:add a warn about '~' in src-imports * Update src/api/sfc-spec.md Co-authored-by: Natalia Tepluhina <[email protected]> * Update src/api/sfc-spec.md Co-authored-by: Natalia Tepluhina <[email protected]> * doc(import statement): add import statement in script setup * doc(import statement): delete extraneous blank lines --------- Co-authored-by: 包伟斌 <[email protected]> Co-authored-by: Natalia Tepluhina <[email protected]>
Vue version
3.4.31
Link to minimal reproduction
https://play.vuejs.org/#eNp9kUtLAzEUhf/KcNclg9RVGcUHXehCRV0GZJy5jal5kcc4UMbfbpKhtdCS3eV854ZzbnZwawwZAsIKGo/SiNbjNVVV1fR8yEMcuWSVs90VBVJvtCZGMQrVKb0pUxM+i4bfMj2z3tRzyqY+yg4L8K7TasMZ2TqtYrVdMlPotDRcoH02nmvlKKyqTBJrhdA/j1nzNuBir3df2H2f0bduTBqFF4sO7YAUDsy3lqGf8frtCcc4H6DUfRDRXYCv6LQIKeNsuwuqj7GPfDntgzTaeq7Yu1uPHpXbl0pBk3PKfgrxf+8L1f/jLsll3qNqilf8GNCmN+MBIyDLC5j+AF8xsX8=
Steps to reproduce
See the
JS
tab in the playground.are transformed to:
What is expected?
What is actually happening?
System Info
Any additional comments?
Refer to a vite issue
Refer to code caused the issue
@vue/compiler-sfc
handles assets in template. If a element links to a absolute url, just use it. If links to a relative url, will import it. The url starts with. and ~ and @
will be considered a relative path , for~ and @
are common aliases.However, code here removed
~
and~/
at the beginning of the url, which caused compilation differences just due to different alias names. So I think that should be a bug.The text was updated successfully, but these errors were encountered: