定制 draggable/formeo 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

draggable/formeo

Composer 安装命令:

composer require draggable/formeo

包简介

Drag and Drop Javascript form builder

README 文档

README

A highly configurable drag & drop form building module for creating dynamic, responsive forms with an intuitive visual editor.

npm npm downloads GitHub build

Demo

formeo-demo

Table of Contents

Features

  • 🎯 Drag & Drop Editing - Intuitive visual form builder
  • 📐 Column/Inline Layout - Create multi-column forms and inline field groups
  • 🔀 Conditional Fields - Show/hide fields based on user input
  • 🎨 Custom Controls - Extensible control API for custom field types
  • 🌍 i18n Support - Multi-language support out of the box
  • 📱 Responsive - Mobile-friendly form editor and renderer
  • Zero Config - Works out of the box with sensible defaults
  • 🔧 Highly Configurable - Extensive options and event system
  • 📦 TypeScript Support - Full type definitions included
  • 🎭 Preview Mode - Test forms before deployment

Installation

NPM

npm install formeo

Yarn

yarn add formeo

CDN

For quick prototyping or simple projects, you can use a CDN:

<!-- JavaScript -->
<script src="https://unpkg.com/formeo@latest/dist/formeo.umd.js"></script>

<!-- CSS -->
<link rel="stylesheet" href="https://unpkg.com/formeo@latest/dist/formeo.min.css">

Usage

Basic Setup

First, import Formeo into your project:

import { FormeoEditor, FormeoRenderer } from 'formeo'
import 'formeo/dist/formeo.min.css'

Creating a Form Editor

// Create a container element in your HTML
// <div id="formeo-editor"></div>

const editorOptions = {
  editorContainer: '#formeo-editor',
  // Add any additional options here
}

// Initialize the editor
const editor = new FormeoEditor(editorOptions)

Saving Form Data

// Get the form data (typically in an onSave event)
const formData = editor.formData

// Save to your backend
fetch('/api/forms', {
  method: 'POST',
  headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(formData)
})

Rendering a Form

// Create a container element for the rendered form
// <div id="formeo-renderer"></div>

const rendererOptions = {
  editorContainer: '#formeo-renderer',
  // Add any additional options here
}

// Initialize the renderer and render the form
const renderer = new FormeoRenderer(rendererOptions)
renderer.render(formData)

Complete Example

import { FormeoEditor, FormeoRenderer } from 'formeo'
import 'formeo/dist/formeo.min.css'

// Set up the editor
const editor = new FormeoEditor({
  editorContainer: '#formeo-editor',
  events: {
    onSave: (formData) => {
      console.log('Form saved:', formData)
      // Render the form
      renderer.render(formData)
    }
  }
})

// Set up the renderer
const renderer = new FormeoRenderer({
  editorContainer: '#formeo-renderer'
})

TypeScript

Formeo includes TypeScript definitions. Import and use with full type support:

import { FormeoEditor, FormeoRenderer } from 'formeo'
import type { FormeoOptions, FormData } from 'formeo'

const options: FormeoOptions = {
  editorContainer: '#formeo-editor'
}

const editor = new FormeoEditor(options)
const formData: FormData = editor.formData

Framework Integration

Formeo can be integrated with popular frontend frameworks:

Documentation

Comprehensive documentation is available in the docs directory:

  • Options - Complete configuration reference
  • Controls - Custom field types and controls API
  • Events - Available events and callbacks
  • Actions - Action handlers
  • Editor API - Editor methods and properties
  • Build Tools - Development and build utilities

Development

Prerequisites

  • Node.js (v18 or higher)
  • npm or yarn

Getting Started

# Clone the repository
git clone https://github.com/Draggable/formeo.git
cd formeo

# Install dependencies
npm install

# Start development server
npm start

The demo will be available at http://localhost:5173/

Available Scripts

npm run dev          # Start development server
npm run build        # Build library and demo
npm run build:lib    # Build library only
npm test             # Run tests
npm run lint         # Lint code
npm run format       # Format code with Biome

Running Tests

# Unit tests
npm test

# End-to-end tests
npm run playwright:test

# View test report
npm run playwright:test:report

Contributing

We welcome contributions! Please see our Contributing Guide for details on:

  • Setting up your development environment
  • Code style and conventions
  • Submitting pull requests
  • Reporting issues

License

Formeo is MIT licensed.

Docs

Changelog

Made with ❤️ by Draggable

统计信息

  • 总下载量: 169
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 601
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 600
  • Watchers: 35
  • Forks: 202
  • 开发语言: JavaScript

其他信息

  • 授权协议: MIT
  • 更新时间: 2016-07-26

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固