单片机设计_串口调试工具

一、设计思路

  1. HTML结构完整 - 标签闭合正确

  2. CSS样式齐全 - 浅绿色主题,响应式布局

  3. JavaScript逻辑完整 - 串口连接、读写、错误处理齐全

🎯 功能清单

功能模块 说明
串口连接 支持选择设备,配置波特率/数据位/停止位/校验位/流控
数据接收 支持字符串/HEX显示,自动滚动
数据发送 支持字符串/HEX模式,可选换行符,Ctrl+Enter快捷键
界面主题 浅绿色护眼风格

二、界面展示

三、部分代码

html 复制代码
<body>
<div class="serial-panel">
    <div class="panel-header">
        <div class="title">
            <h1>🍃 串口调试</h1>
            <div class="badge">Web Serial API</div>
        </div>
        <div class="status-area">
            <div class="led" id="statusLed"></div>
            <div class="status-text" id="statusText">未连接</div>
        </div>
    </div>

    <div class="control-bar">
        <div class="param-group">
            <label>波特率</label>
            <select id="baudRate">
                <option value="9600">9600</option>
                <option value="19200">19200</option>
                <option value="38400">38400</option>
                <option value="57600">57600</option>
                <option value="115200" selected>115200</option>
                <option value="230400">230400</option>
                <option value="460800">460800</option>
            </select>
        </div>
        <div class="param-group">
            <label>数据位</label>
            <select id="dataBits">
                <option value="7">7</option>
                <option value="8" selected>8</option>
            </select>
        </div>
        <div class="param-group">
            <label>停止位</label>
            <select id="stopBits">
                <option value="1">1</option>
                <option value="2">2</option>
            </select>
        </div>
        <div class="param-group">
            <label>校验位</label>
            <select id="parity">
                <option value="none">None</option>
                <option value="even">Even</option>
                <option value="odd">Odd</option>
            </select>
        </div>
        <div class="param-group">
            <label>流控</label>
            <select id="flowControl">
                <option value="none">None</option>
                <option value="hardware">Hardware</option>
            </select>
        </div>
        <button id="connectBtn" class="primary">🔌 连接设备</button>
        <button id="disconnectBtn" class="danger">⛔ 断开</button>
    </div>

    <div class="main-area">
        <!-- 接收区域 -->
        <div class="log-panel">
            <div class="section-title">
                <span>📥 数据接收 (RX)</span>
                <button id="clearReceiveBtn" class="clear-btn">清空接收区</button>
            </div>
            <div class="receive-area">
                <div class="log-box" id="receiveLog">
                    [等待连接串口设备...]<br>
                </div>
            </div>
        </div>

        <!-- 发送区域 -->
        <div class="send-panel">
            <div class="section-title">
                <span>📤 数据发送 (TX)</span>
                <button id="clearSendInputBtn" class="clear-btn">清空编辑区</button>
            </div>
            <div class="input-area">
                <textarea id="sendData" placeholder="输入要发送的字符串或十六进制 (根据下方模式)"></textarea>
                <div class="send-options">
                    <div class="checkbox-label">
                        <input type="checkbox" id="hexSendMode"> <span>HEX 发送模式</span>
                    </div>
                    <div class="checkbox-label">
                        <input type="checkbox" id="appendNewline" checked> <span>发送换行符 \r\n</span>
                    </div>
                    <button id="sendBtn" style="flex:1;">✈️ 发送数据</button>
                </div>
                <div class="send-options" style="margin-top: 12px;">
                    <div class="checkbox-label">
                        <input type="checkbox" id="hexReceiveMode"> <span>HEX 显示模式</span>
                    </div>
                    <div class="checkbox-label">
                        <input type="checkbox" id="autoScroll" checked> <span>自动滚动</span>
                    </div>
                    <button id="clearReceiveBtn2" class="clear-btn">清空接收</button>
                </div>
            </div>
        </div>
    </div>
    <footer>
        💡 浅绿护眼主题 | 支持HEX/字符串收发 | 有问题联系-liming-
    </footer>
</div>
相关推荐
鹿角片ljp1 小时前
从告警检测到智能研判:SQL 注入研判模型的设计与实践
数据库·sql
CHANG_THE_WORLD2 小时前
PE文件二进制对比
stm32·单片机·嵌入式硬件
小新同学^O^2 小时前
简单学习 --> Spring事务
数据库·学习·spring
前进的李工3 小时前
MySQL慢查询日志优化实战
数据库·mysql·性能优化
KaMeidebaby3 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
ECT-OS-JiuHuaShan3 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算
八月瓜科技3 小时前
用AI来省电?iOS26.5正式版全球推送:信号弱网双提升,AI省电模式上新
数据库·人工智能·科技·深度学习·机器人
dhashdoia3 小时前
GPT-5.5 代码开发实战:Codex与Browser Use深度集成与星链4SAPI优化方案
java·数据库·人工智能·gpt·架构