使用Vite+ Lit 构建webcomponent 组件

使用 Vite + Lit 构建 WebComponent 组件

初始化项目

创建一个新的 Vite 项目并选择适合的模板(如 vanillavanilla-ts)。运行以下命令:

复制代码
npm create vite@latest my-lit-element --template vanilla
cd my-lit-element
npm install

安装 Lit 依赖:

复制代码
npm install lit
配置 Vite

确保 Vite 配置文件支持 WebComponent 开发。在 vite.config.js 中,添加以下配置以启用自定义元素:

复制代码
import { defineConfig } from 'vite';

export default defineConfig({
  build: {
    lib: {
      entry: 'src/my-component.js',
      name: 'MyComponent',
      fileName: 'my-component',
      formats: ['es']
    }
  }
});
创建 Lit 组件

src 目录下创建组件文件(如 my-component.js)。使用 Lit 的 htmlcss 模板标签定义组件:

复制代码
import { LitElement, html, css } from 'lit';

class MyComponent extends LitElement {
  static styles = css`
    :host {
      display: block;
      padding: 16px;
      color: #333;
    }
  `;

  static properties = {
    message: { type: String }
  };

  constructor() {
    super();
    this.message = 'Hello, Lit!';
  }

  render() {
    return html`<div>${this.message}</div>`;
  }
}

customElements.define('my-component', MyComponent);
开发与构建

启动开发服务器:

复制代码
npm run dev

构建生产版本:

复制代码
npm run build

构建后会生成 dist 目录,包含可直接使用的 ES 模块文件。

使用组件

在 HTML 中通过模块导入方式使用组件:

复制代码
<!DOCTYPE html>
<html>
  <head>
    <script type="module" src="/src/my-component.js"></script>
  </head>
  <body>
    <my-component message="Custom Message"></my-component>
  </body>
</html>
可选:TypeScript 支持

若使用 TypeScript,安装类型定义并更新组件文件为 .ts

复制代码
npm install --save-dev @types/webcomponents @types/trusted-types

示例 TypeScript 组件:

复制代码
import { LitElement, html, css } from 'lit';
import { customElement, property } from 'lit/decorators.js';

@customElement('my-component')
export class MyComponent extends LitElement {
  @property({ type: String }) message = 'Hello, Lit!';

  static styles = css`
    :host {
      display: block;
      padding: 16px;
    }
  `;

  render() {
    return html`<div>${this.message}</div>`;
  }
}
注意事项
  • 确保组件名称包含连字符(如 my-component),符合 WebComponents 规范。
  • 使用 :host 选择器定义组件根样式。
  • 通过 static properties 或装饰器声明属性以支持响应式更新。
相关推荐
星越华夏2 分钟前
计算机视觉:YOLOv12安装环境
人工智能·yolo·计算机视觉
Yolanda941 小时前
【人工智能】《从零搭建AI问答助手项目(九):Prompt优化》
人工智能·prompt
wj3055853781 小时前
课程 9:模型测试记录与 Prompt 策略
linux·人工智能·python·comfyui
小和尚同志1 小时前
深入使用 skill-creator:结合真实生产级实践
人工智能·aigc
DevSecOps选型指南1 小时前
安全419专访悬镜安全 | 穿越周期在 AI 浪潮中定义数字供应链安全新范式
人工智能
沪漂阿龙2 小时前
面试题详解:GraphRAG 全面解析——知识图谱增强 RAG、Local Search、Global Search、社区摘要、工程落地与评估指标一次讲透
人工智能·知识图谱
WangN22 小时前
Unitree RL Lab 学习笔记【通识】
人工智能·机器学习
haina20192 小时前
海纳AI亮相《科创中国》,解码招聘“智”变之路
人工智能·ai面试·ai招聘
阿星AI工作室2 小时前
刘润年中大课笔记:一句话说清AI落地之战的本质
大数据·人工智能·创业创新·商业
qingfeng154152 小时前
企业微信机器人开发:如何实现自动化与智能运营?
人工智能·python·机器人·自动化·企业微信