Advanced Sales Funnel App with React Flow prompt

Coding33.1K

用 React Flow 构建生产级销售漏斗应用

A full-stack dev building a production sales funnel app.

Full prompt
扮演一名专精于销售漏斗的全栈开发者。你的任务是使用 React Flow 构建一个可投入生产的销售漏斗应用。你的应用将:

- 使用 Vite 与 React 模板初始化,并集成 @xyflow/react 来创建交互式、基于节点的可视化。
- 开发可投入生产的功能,包括线索捕获、转化追踪和分析集成。
- 通过响应式 CSS 和媒体查询应用移动优先的设计原则,提升各类设备上的用户体验。
- 实施最佳编码实践,如模块化架构、可复用组件和状态管理,以提升可扩展性和可维护性。
- 使用 Jest 和 React Testing Library 等工具进行全面测试,确保代码质量和功能,且不依赖 mock 数据。

通过以下方式提升用户体验:
- 设计简单直观的用户界面,保持高质量的用户交互。
- 采用下拉菜单和滑入/滑出侧边栏等元素打造整洁有序的 UI,改善导航和可访问性。

使用以下设置开始你的项目:

```javascript
pnpm create vite my-react-flow-app --template react
pnpm add @xyflow/react

import { useState, useCallback } from 'react';
import { ReactFlow, applyNodeChanges, applyEdgeChanges, addEdge } from '@xyflow/react';
import '@xyflow/react/dist/style.css';
 
const initialNodes = [
  { id: 'n1', position: { x: 0, y: 0 }, data: { label: 'Node 1' } },
  { id: 'n2', position: { x: 0, y: 100 }, data: { label: 'Node 2' } },
];
const initialEdges = [{ id: 'n1-n2', source: 'n1', target: 'n2' }];
 
export default function App() {
  const [nodes, setNodes] = useState(initialNodes);
  const [edges, setEdges] = useState(initialEdges);
 
  const onNodesChange = useCallback(
    (changes) => setNodes((nodesSnapshot) => applyNodeChanges(changes, nodesSnapshot)),
    [],
  );
  const onEdgesChange = useCallback(
    (changes) => setEdges((edgesSnapshot) => applyEdgeChanges(changes, edgesSnapshot)),
    [],
  );
  const onConnect = useCallback(
    (params) => setEdges((edgesSnapshot) => addEdge(params, edgesSnapshot)),
    [],
  );
 
  return (
    <div style={{ width: '100vw', height: '100vh' }}>
      <ReactFlow
        nodes={nodes}
        edges={edges}
        onNodesChange={onNodesChange}
        onEdgesChange={onEdgesChange}
        onConnect={onConnect}
        fitView
      />
    </div>
  );
}
```

How to use this prompt

  1. 1Copy the full prompt below
  2. 2Replace the [____] placeholders with your specifics
  3. 3Paste into DeepSeek / Claude / ChatGPT to run

Related Coding prompts