Skip to content

Write components once, run everywhere. Compiles to React, Vue, Qwik, Solid, Angular, Svelte, and more.(低成本、无框架、跨技术栈,构建你的跨技术栈/原生组件。组件可运行于任何前端框架!)

License

Notifications You must be signed in to change notification settings

TangMoonDrift/quark-core

 
 

Repository files navigation

Quarkc

Quarkc,跨技术栈/原生组件构建工具。组件可运行于任何前端框架!
哈啰集团前端公共组件构建工具,已支撑哈啰几乎所有 C 端 / B 端项目,包括交易,支付,两轮,商城等。

Total Downloads Published on NPM License

简体中文 | English

联系我们

微信扫码,可进技术交流群

优秀案例

作者 github 地址 截图 / 链接
@yuhaiyang1 https://github.com/yuhaiyang1/quarkc-time https://unpkg.com/[email protected]/demo.html
@khno https://github.com/khno/quark-element-demo-celebrate https://unpkg.com/quarkc-demo-celebrate@latest/demo.html
@hellof2e https://github.com/hellof2e/quark-doc-header 1685501041275 https://quark.hellobike.com/#/
@xsf0105 https://github.com/xsf0105/dark-light-element https://unpkg.com/dark-light-element@latest/demo.html
@dyf19118 https://github.com/dyf19118/quark-ui-rate image
@hellof2e https://github.com/hellof2e/quark-doc-home 1686575964690

介绍

Quarkc(Quark core缩写) 是一个拥有完美开发体验的 web components 工具。通过它,您可以开发标准的 跨框架组件

Why Quarkc ?

背景 1:【前端的历史】

前端发展多年,无论大小公司,一般都存在各种技术栈(React, Angular, Jq, Vue) / 同种技术栈的不同版本(Vue2, Vue3)。如果要开发某个通用组件(比如:营销弹窗),工作量就是 double+(不同技术框架需要分开开发/维护/上线,同技术不同版本可能也需要分开开发/维护/上线)

背景 2:【前端的未来】

前端框架会继续迭代/发展,会有新的版本,新的框架出现。用 Quarkc 开发“通用型组件”,不会随着“前端框架浪潮”而更新迭代(极大降低组件研发/维护成本)。

以上背景,决定了 前端通用型组件 的开发和维护成本比较高。

Quarkc 目标

让 Web 组件实现技术栈无关!

使用

组件起手架模版

  1. 工程安装
npx create-quark-app create project-name
cd project-name

npm install
npm start
  1. 自定义组件
import { QuarkElement, property, customElement } from "quarkc"
import style from "./index.less?inline"

@customElement({ tag: "my-element", style }) // 自定义标签/组件、CSS
export default class MyElement extends QuarkElement {
  @property() // 外部属性
  count

  add = () => {
    this.count += 1
  }

  render() {
    return (
      <button onClick={this.add}>count is: { this.count }</button>
    )
  }
}
  1. 使用

各种技术栈都能运行。

<my-element count="count" />

<!-- vue -->
<my-element :count="count" />

<!-- react -->
<my-element count={count} />

<!-- svelte -->
<my-element {count} />

<!-- angular -->
<my-element [count]="count" />

组件打包

打包默认输出为 UMD / ESM 格式

npm run build

此时,构建产物 lib/ 下的资源可以直接在项目中被使用。(任何前端项目都可使用~)

import "your-element"

<my-element></my-element>

组件发布

可以将组件发布到 npm,安装:

npm install your-element

可以作为 CDN 使用

<script src="https://fastly.jsdelivr.net/npm/quarkc"></script>
<script src="https://fastly.jsdelivr.net/npm/your-element"></script>

也可以作为 ES Module 使用(推荐)

import "your-element"

更多发布相关,详情点击 发布 Publishing

特性

  • 跨技术栈:组件可以在任何框架或无框架的环境下使用,让你的代码更具复用性
  • 组件体积极小,性能极高:因为 Quarkc 使用的是浏览器原生 API,所以你的组件可以达到最优性能,且体积小巧
  • Web Components, Simple, Fast!
  • 浏览器原生API,组件可以跨技术栈使用
  • 没有前端框架 Runtime,Web 组件体积小到极致
  • 高性能设计,Shadow DOM 与 Virtual DOM 融合
  • 组件直接解耦,独立打磨,按需引用

性能参考

一个略复杂的组件页面跑分截图:

image

文档

完整文档,请访问 quark.hellobike.com

About

Write components once, run everywhere. Compiles to React, Vue, Qwik, Solid, Angular, Svelte, and more.(低成本、无框架、跨技术栈,构建你的跨技术栈/原生组件。组件可运行于任何前端框架!)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 74.8%
  • TypeScript 22.5%
  • Less 1.6%
  • HTML 1.1%