如何用Web Serial API与串口设备通信?

Web Serial API允许网页通过浏览器直接与串口设备通信,需用户点击触发连接,使用requestPort选择设备并设置正确波特率(如9600),通过readable流持续读取Uint8Array数据并解码,利用writable流发送格式化指令(如添加换行符),同时监听disconnect事件及捕获异常以应对断连或错误,适用于物联网调试与教育项目。

如何用web serial api与串口设备通信?

Web Serial API 让网页可以直接与串口设备(如 Arduino、传感器、单片机等)通信,无需安装额外驱动或客户端软件。它运行在现代浏览器中,主要支持 Chrome 和基于 Chromium 的浏览器(如 Edge)。以下是使用 Web Serial API 与串口设备通信的基本步骤和注意事项。

请求连接串口设备

用户必须主动触发设备选择,不能自动连接。通常通过按钮点击来发起请求:

const button = document.getElementById('connect');button.addEventListener('click', async () => {  try {    // 请求用户选择一个串口设备    const port = await navigator.serial.requestPort();    await port.open({ baudRate: 9600 }); // 常见波特率:9600, 115200 等    console.log('已连接到设备');  } catch (e) {    console.error('无法连接设备:', e);  }});

注意:baudRate 必须与设备设置一致,否则通信会失败。

读取串口数据

打开端口后,可以创建一个读取循环来持续接收数据:

async function readSerial(port) {  const reader = port.readable.getReader();  while (true) {    const { value, done } = await reader.read();    if (done) {      reader.releaseLock();      break;    }    // value 是 Uint8Array,转换为文本    const text = new TextDecoder().decode(value);    console.log('收到:', text);  }}

调用 readSerial(port) 后,即可实时处理从设备发来的数据。常见格式为换行分隔的字符串,可进一步解析。

发送数据到设备

通过 writable 流向设备写入数据:

SpeakingPass-打造你的专属雅思口语语料 SpeakingPass-打造你的专属雅思口语语料

使用chatGPT帮你快速备考雅思口语,提升分数

SpeakingPass-打造你的专属雅思口语语料 25 查看详情 SpeakingPass-打造你的专属雅思口语语料

async function sendSerial(port, message) {  const writer = port.writable.getWriter();  const data = new TextEncoder().encode(message + 'n'); // 添加换行符便于设备识别  await writer.write(data);  writer.releaseLock();}// 示例:发送命令sendSerial(port, 'LED ON');

发送的内容通常需按设备协议格式化,比如添加回车、制表符或特定指令前缀。

处理连接变化和错误

设备可能被拔出或断开,应监听连接状态:

navigator.serial.addEventListener('disconnect', (event) => {  console.log('设备已断开', event.target);  // 可提示用户重新连接});

同时,在 open() 和读写操作中使用 try-catch 捕获异常,提升稳定性。

基本上就这些。Web Serial API 简化了网页与硬件的交互,适合物联网调试、教育项目或控制面板类应用。只要注意用户手势触发、波特率匹配和数据编解码,就能稳定通信。

以上就是如何用Web Serial API与串口设备通信?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/319611.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 09:21:15
下一篇 2025年11月5日 09:22:12

相关推荐

  • 探索 Python 的 itertools 模块:释放迭代器的力量

    在 python 编程领域,迭代器在促进数据结构的高效且内存友好的迭代方面发挥着至关重要的作用。 python 中的 itertools 模块是一个功能强大的工具包,它提供了大量用于创建和操作迭代器的函数。在本文中,我们将深入研究 python 的 itertools 模块,以释放其全部潜力并了解它…

    2025年12月13日 好文分享
    000
  • Python 应用程序的 Dockerfile

    让我们为 python 应用程序创建一个简单的 dockerfile。此示例假设您有一个名为 app.py 的 python 脚本和一个包含应用程序依赖项的requirements.txt 文件。 打开终端。导航到要创建或编辑 dockerfile 的目录。输入 vi dockerfile 并按 e…

    2025年12月13日
    000
  • Dockerized lambda 函数中的相对 Python 导入

    相对 python 导入对于 lambda 函数来说可能很棘手。我三年前写过一篇关于此的博客。但最近,我在 dockerized lambda 函数方面遇到了同样的问题。所以,我想是时候创建一个新博客了! 您可以按照步骤操作或直接在 github 上查看结果。 项目设置 确保您安装了 aws cdk…

    2025年12月13日
    000
  • Python Day-String 使用循环函数逻辑,任务

    1) find(): 在字符串中搜索指定值并返回找到它的位置。 txt = “i love many fruits, apple is my favorite fruit”key = ‘fruit’l = len(key)start = 0 end = lwhile end<=len(txt)…

    2025年12月13日
    000
  • 可扩展软件架构的基本 Python 设计模式

    作为一名拥有多年经验的 python 开发人员,我逐渐认识到设计模式在构建健壮且可扩展的软件架构方面的力量。在本文中,我将分享我对六种基本 python 设计模式的见解,这些模式在实际项目中不断证明了它们的价值。 让我们从单例模式开始。这种模式确保一个类在整个应用程序中只有一个实例。它对于管理共享资…

    2025年12月13日
    000
  • Faiss 与 RAG 的 sqlite

    想要使用 faiss 进行本地 RAG 吗?好的,但是在哪里存储我的块(元数据)。 解决方案:将 faiss 与 sqlite(或任何其他 sql)连接。 如何:将向量保存在 faiss 中,将数据保存在 sqlite 中。 好处: 使用 faiss 处理矢量数据(它的用途),使用 sqlite 处…

    2025年12月13日
    000
  • Python 基本语法和缩进:完整的初学者指南

    当你第一次学习编程时,python 因一个特殊原因而脱颖而出:它的设计目的几乎像英语一样阅读。与使用大量符号和括号的其他编程语言不同,python 依赖于简单、干净的格式,使您的代码看起来像组织良好的文档。 将 python 的语法视为语言的语法规则。正如英语有关于如何构造句子以使含义清晰的规则一样…

    2025年12月13日
    000
  • 在 Conky 面板上显示 Python 脚本输出

    在这篇文章中,我将演示一种使用 python 和 conky 直接在桌面面板上显示来自 api 请求的数据的简单方法。 客观的 目标是从 api 获取信息并将其显示在桌面面板上。在此示例中,我将使用 python 来处理 api 请求,并使用 conky 来创建面板。 我们将使用 economia.…

    2025年12月13日
    000
  • 使用 Python 中的 Serengil/DeepFace 库分析情绪、年龄和性别

    在本文中,我们将讨论如何使用 serengil 的 deepface 库来分析面部图像中的情绪、年龄和性别。本文将包括四个主要部分:(1)所使用的库的讨论,(2)如何使用库,(3)代码解释,以及(4)分析结果。 1。 deepface 库的讨论deepface 是一个基于 python 的开源库,提…

    2025年12月13日
    000
  • CelebA 是 PyTorch

    请我喝杯咖啡☕ *我的帖子解释了 celeba。 celeba() 可以使用 celeba 数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 split(可选-默认:”train&#822…

    2025年12月13日 好文分享
    000
  • PyTorch 中的加州理工学院

    请我喝杯咖啡☕ *我的帖子解释了加州理工学院 101。 caltech101()可以使用caltech 101数据集,如下所示: *备忘录: 第一个参数是 root(必需类型:str 或 pathlib.path)。 *绝对或相对路径都是可能的。第二个参数是 target_type(可选-默认:“c…

    2025年12月13日
    000
  • 变革发展:呼吁创新者和合作者

    自 2017 年以来,我一直致力于创建一个重新定义开发人员编码方式的解决方案。作为一个热衷于创新和创造性解决问题的人,我设想了一种可以简化复杂编码流程、消除冗余并帮助开发人员充分发挥潜力的工具。这个项目一直是我的热情所在,代表了多年的集思广益、规划和完善。虽然 2020 年生活给我带来了一些挑战,导…

    2025年12月13日
    000
  • 确保芹菜的公平加工 – 第二部分

    本文在上一篇有关公平处理的文章的基础上探讨了 celery 中的任务优先级。任务优先级提供了一种通过根据自定义标准为任务分配不同优先级来增强后台处理的公平性和效率的方法。 为什么任务级优先级? 任务级优先级提供对任务执行的细粒度控制,无需复杂的实现。通过将所有任务提交到具有指定优先级值的单个队列,工…

    2025年12月13日
    000
  • 如何为 Code 4 的出现编写排序算法

    在上一篇文章中,我简单提到我将参加今年的“代码降临”活动。巧合的是,在其中一个谜题中,特别是在第 5 天发布的谜题中,涉及修复列表中页面的顺序。这是在我发布关于实现排序算法的文章后不久,所以我认为我应该写一下它。 描绘某种排序算法的可爱图像 对于那些没有听说过“advent of code”的人来说…

    2025年12月13日
    000
  • Day – 字符串函数

    1.编写一个程序来检查给定的密钥是否可用: txt = “i love many fruits, apple is my favorite fruit”key = ‘fruit’l = len(key)start = 0 end = lwhile end<=len(txt): if txt[s…

    2025年12月13日
    000
  • 使用 Python 和 NumPy 为神经网络创建简单高效的遗传算法

    这是有关 ml 进化算法课程的第一篇文章。 当你知道神经网络的参数,但不知道输出应该是什么时,就需要遗传算法,例如,这个算法可以用来玩 google dinosaur 或 flappy bird,因为你不知道输出应该是什么,但您有能力对最可行的选项进行排序,例如按时间,这称为适应度函数。 我一直没能…

    2025年12月13日
    000
  • 使用 Python 请求模块使 HTTP 变得简单

    简介 http 是一种基于 tcp/ip 的应用层通信协议,它标准化了客户端和服务器之间的通信方式。它用于使用超文本链接加载网页。 “无论您是从 api 获取数据还是提交表单数据,python 中的 requests 库都是您的首选工具,可以让 http 请求无缝且直观。” 如何安装请求 在终端中输…

    2025年12月13日
    000
  • 掌握 Python 并发编程:利用先进技术提升性能

    python 的并发编程能力已经显着发展,为开发人员提供了编写高效、并行代码的强大工具。我花了相当多的时间探索这些先进技术,很高兴与您分享我的见解。 使用 asyncio 进行异步编程是 i/o 密集型任务的游戏规则改变者。它允许我们编写非阻塞代码,可以同时处理多个操作,而无需线程开销。下面是一个简…

    2025年12月13日
    000
  • ChatsAPI — 世界上最快的人工智能代理框架

    github: https://github.com/chatsapi/chatsapi图书馆: https://pypi.org/project/chatsapi/ 人工智能已经改变了各行各业,但有效部署人工智能仍然是一项艰巨的挑战。复杂的框架、缓慢的响应时间和陡峭的学习曲线给企业和开发人员带来了…

    2025年12月13日 好文分享
    000
  • 最大化间隔

    每周挑战 298 穆罕默德·s·安瓦尔 (mohammad s. anwar) 每周都会发出“每周挑战”,让我们所有人都有机会为每周两次的任务提出解决方案。这对我们所有人来说都是练习编码的好方法。 挑战,我的解决方案 任务 1:最大平方 任务 给你一个只有 0 和 1 的 m x n 二进制矩阵。 …

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信