Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vue-vine/vue-vine
Another style of writing Vue components.
https://github.com/vue-vine/vue-vine
Last synced: 7 days ago
JSON representation
Another style of writing Vue components.
- Host: GitHub
- URL: https://github.com/vue-vine/vue-vine
- Owner: vue-vine
- License: mit
- Created: 2023-05-26T08:09:54.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2025-02-06T10:02:17.000Z (14 days ago)
- Last Synced: 2025-02-06T10:03:47.851Z (14 days ago)
- Language: TypeScript
- Homepage: https://vue-vine.dev
- Size: 3.91 MB
- Stars: 1,300
- Watchers: 11
- Forks: 63
- Open Issues: 0
-
Metadata Files:
- Readme: README-CN.md
- Contributing: CONTRIBUTING-zhCN.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Vue Vine
- [English README](./README.md)
- [贡献指南](./CONTRIBUTING-zhCN.md)创造另一种书写 Vue 组件的方式。
- NPM 版本: [data:image/s3,"s3://crabby-images/02af0/02af08f65f3693db79221814704c840f7e2dcd27" alt="NPM Version"](https://www.npmjs.com/package/vue-vine)
- VSCode 插件版本: [data:image/s3,"s3://crabby-images/64d81/64d81f8e4a182b0802af15118e9fe12b5e0c5aa8" alt="VSCode ext version"](https://marketplace.visualstudio.com/items?itemName=shenqingchuan.vue-vine-extension)
- Open VSX 插件版本: [data:image/s3,"s3://crabby-images/7f66e/7f66e199536b049fcbf33227c999132b39858c90" alt="Open VSX ext version"](https://open-vsx.org/extension/shenqingchuan/vue-vine-extension)
- 要了解更多细节,请查看 [官方文档](https://vue-vine.dev): [data:image/s3,"s3://crabby-images/cc38c/cc38cbaebdb82407b16996915b911e91a94c42e2" alt="Netlify Status"](https://app.netlify.com/sites/vue-vine/deploys)
为什么做这样一个项目?
在社区中,有很多帖子讨论过希望有一个支持在单个文件中编写多个 Vue 组件的解决方案。`Vue Vine` 因此而生。
`Vue Vine` 旨在提供更多管理 Vue 组件的灵活性,它并不是要取代 Vue SFC,而是作为一种并行的解决方案。
下面是一个简单的示例预览:
data:image/s3,"s3://crabby-images/e1148/e11482b22736895d24c16dccd1f087f743957628" alt="示例预览"
## 尝试示例
使用交互式命令(`create-vue-vine`)创建您的第一个项目。看这里: [项目启动模板](https://vue-vine.dev/zh/introduction/ecosystem.html#project-starter-template)
或者你可以在线上尝试: [Vue Vine Playground](https://stackblitz.com/~/github.com/vue-vine/stackblitz-playground)
## 项目 NPM 包总览
| 类别 | 包名 | 版本 | 简介 |
| --- | --- | --- | --- |
| data:image/s3,"s3://crabby-images/3d525/3d525b4d34d7edae233438d96393be6ce40a2be7" alt="core" | [@vue-vine/compiler](./packages/compiler) | [data:image/s3,"s3://crabby-images/e82b5/e82b59530aa91e45f9cafc8f4648069bbe0ab1c4" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/compiler) | 编译器 |
| data:image/s3,"s3://crabby-images/3d525/3d525b4d34d7edae233438d96393be6ce40a2be7" alt="core" | [@vue-vine/language-server](./packages/language-server) | [data:image/s3,"s3://crabby-images/a42a8/a42a8bc32b0563067d0c222a8b055367fa46bb05" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/language-server) | 语言服务器 |
| data:image/s3,"s3://crabby-images/3d525/3d525b4d34d7edae233438d96393be6ce40a2be7" alt="core" | [@vue-vine/language-service](./packages/language-service) | [data:image/s3,"s3://crabby-images/1ccfb/1ccfba19806e4b68a2aeb3c6bb4ab42f300a10eb" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/language-service) | 语言服务集成 |
| data:image/s3,"s3://crabby-images/3d525/3d525b4d34d7edae233438d96393be6ce40a2be7" alt="core" | [@vue-vine/vite-plugin](./packages/vite-plugin) | [data:image/s3,"s3://crabby-images/f1d29/f1d29d12d12ad5f590c1c46c2f488a495bf60861" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/vite-plugin) | Vite 插件 |
| data:image/s3,"s3://crabby-images/6e397/6e3970f32376d5af991db7783d70bea9f6d7905b" alt="eslint" | [@vue-vine/eslint-parser](./packages/eslint-parser) | [data:image/s3,"s3://crabby-images/4d373/4d3739b71a2e4f3a5e9d66ea6cd76ece94b48a7e" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/eslint-parser) | ESLint 自定义解析器 |
| data:image/s3,"s3://crabby-images/6e397/6e3970f32376d5af991db7783d70bea9f6d7905b" alt="eslint" | [@vue-vine/eslint-plugin](./packages/eslint-plugin) | [data:image/s3,"s3://crabby-images/172bc/172bc78d5f09672379121925f56db97d3a9c85a0" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/eslint-plugin) | ESLint 插件 |
| data:image/s3,"s3://crabby-images/6e397/6e3970f32376d5af991db7783d70bea9f6d7905b" alt="eslint" | [@vue-vine/eslint-config](./packages/eslint-config) | [data:image/s3,"s3://crabby-images/29e69/29e69222e5b5c8d0d62eb669bab7433b66c81014" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/eslint-config) | ESLint 配置 |
| data:image/s3,"s3://crabby-images/12e5d/12e5d4009547169e1f90034525a7e930945298f0" alt="nuxt" | [@vue-vine/nuxt](./packages/nuxt-module) | [data:image/s3,"s3://crabby-images/b99f7/b99f705d55864d93fd28d9b2e9c49d729f915504" alt="NPM Version"](https://www.npmjs.com/package/@vue-vine/nuxt) | Nuxt Module |
| data:image/s3,"s3://crabby-images/af2d3/af2d39da7653b66af378e3d098aa7d8a0dbcd8fa" alt="tsc" | [vue-vine-tsc](./packages/tsc) | [data:image/s3,"s3://crabby-images/6b56f/6b56f8d86ba4bec4f4916b6fc016058c11a613fe" alt="NPM Version"](https://www.npmjs.com/package/vue-vine-tsc) | TypeScript CLI 检查器 |
| data:image/s3,"s3://crabby-images/d9750/d97501a935eaacab037e02e1bd44bf49c426d9db" alt="CLI" | [create-vue-vine](./packages/create-vue-vine) | [data:image/s3,"s3://crabby-images/261a7/261a7ce82d3a269fd22c6283b73a236a41a76992" alt="NPM Version"](https://www.npmjs.com/package/create-vue-vine) | 项目脚手架 CLI |## 安装
```bash
# 如果你还没有安装 `@antfu/ni`,我强烈建议你安装它。
ni -D vue-vine
```在 `vite.config.ts` 中使用插件:
```ts
import { VineVitePlugin } from 'vue-vine/vite'export default defineConfig({
plugins: [
// ...其他插件
VineVitePlugin()
],
})
```然后在 `tsconfig.json` 中添加宏的类型定义:
```json
{
"compilerOptions": {
"types": ["vue-vine/macros"]
}
}
```对于 ESLint, 请安装我们提供的 ESLint 配置包:
```bash
ni -D @vue-vine/eslint-config
```你需要将其载入到 ESLint flat configs 中。
```js
import antfu from '@antfu/eslint-config'// `VueVine()` 返回了一个 ESLint flat config
import VueVine from '@vue-vine/eslint-config'export default antfu(
{
// 第一个选项对象不是 ESLint 的 FlatConfig
// 是 antfu 规则自身的配置
},
...VueVine(),
)
```最后,安装 VSCode 插件,在市场中搜索 `Vue Vine`。
![]()