arduino ide esp32 网页按钮异步请求

前两天刚学,不咋懂,原理可以搜别的博主的文章,这是一个示例

#include<WiFi.h>
#include<WebServer.h>#define ledpin 2const char* ssid="Your ssid"; //写你们家的WiFi名称
const char* password="Your password"; //写你们家的WiFi密码WebServer server(80); //端口号void handleRoot()
{String HTML="<!DOCTYPE html>\<html>\<head><meta charset='utf-8'></head>\<body>\你好,我的朋友!\<br/>\<!--千万不要在<script>的定义内打注释,网页控制台会报错!!!(别问我是怎么知道的,问就是用chatgpt找了一个半小时多)-->\<!--24:创建xmlhttprequest对象-->\<!--25:需要一个参数-->\<!--26:建立连接,请求类别,地址(url),是否是异步请求(不刷新网页)-->\<!--27:发送请求-->\<script>\var xhttp=new XMLHttpRequest();\function ctrl(arg){\xhttp.open('GET','/ctrl?led='+arg,true);\xhttp.send('null');\}\</script>\<!--30:script的定义-->\<button onmousedown=\"ctrl('on')\">开灯</button> <!-- //按钮,button必须带一个参数,当鼠标按下之后执行一个方法,led灯控制字目录后/ctrl?led=后的参数,两个button中间是按钮上的字-->\<button onmousedown=\"ctrl('off')\">关灯</button> <!-- -->\</body>\</html>";server.send(200,"text/html",HTML); //返回成功码,返回类型,返回字符串
}
void ledctrl()
{String state=server.arg("led"); //用来获取网址ctrl?led=后的内容if(state=="on"){digitalWrite(ledpin,HIGH);}else if(state=="off"){digitalWrite(ledpin,LOW);}server.send(200,"text/html","<b>Led is "+state+"</b>."); //<b>你要加粗的文字</b>加粗字体
}void setup()
{// put your setup code here, to run once:Serial.begin(921600);pinMode(ledpin,OUTPUT);WiFi.begin(ssid,password);while(WiFi.status()!=WL_CONNECTED){delay(500);Serial.print(".");}Serial.println("\nWiFi连接成功");Serial.print("WiFi IP地址:");Serial.println(WiFi.localIP());server.on("/",handleRoot);server.on("/hello",[](){server.send(200,"text/html","hello");}); //秘名函数server.onNotFound([](){server.send(200,"text/html;charset=utf-8","没有找到页面!");});server.on("/ctrl",ledctrl); //可以带参数,网址/ctrl?led=后就是参数server.begin();}void loop()
{// put your main code here, to run repeatedly:server.handleClient();
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/680128.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[AIGC] 上传文件:后端处理还是直接阿里云OSS?

在构建Web应用时&#xff0c;我们经常需要处理用户上传的文件。这可能是图片、视频、文档等各种各样的文件。但是&#xff0c;上传文件的方式有很多种&#xff0c;最常见的两种方式是&#xff1a;通过后端处理&#xff0c;或者直接上传至云存储服务&#xff0c;如阿里云OSS。那…

Error和Exception有什么区别?Java中的OutOfMemoryError是什么?如何解决它?什么是Java中的异常处理的最佳实践?

Error和Exception有什么区别&#xff1f; Error和Exception在Java中都表示了某种问题或异常情况&#xff0c;但它们之间存在明显的区别。 严重性&#xff1a; Error&#xff1a;通常表示系统级错误或底层资源错误&#xff0c;如内存不足、系统崩溃等。这些错误是严重的&#x…

AES加密后的密码可以破解吗

AES&#xff08;高级加密标准&#xff09;是一种广泛使用的对称加密算法&#xff0c;设计用来抵御各种已知的攻击方法。AES使用固定块大小的加密块和密钥长度&#xff0c;通常是128、192或256位。它被认为是非常安全的&#xff0c;到目前为止&#xff0c;没有已知的可行方法能够…

【详解】斗地主随机发牌项目

目录 前言&#xff1a; 1.初始化牌 2.洗牌 3.揭牌 总代码&#xff1a; Card类&#xff1a; CardGame类&#xff1a; Main类&#xff1a; 结语&#xff1a; 前言&#xff1a; 斗地主是全国范围内的一种桌面游戏&#xff0c;本节我们来实现一下斗地主中的简单初始化牌、…

uniapp微信小程序开发踩坑日记:uni.request回调函数地狱问题

使用await和async无法解决uniapp中的回调函数地狱问题&#xff0c;因为uni.request并不返回一个 Promise。通常情况下&#xff0c;我们期望await能够等待一个 Promise 或者其它类似 Promise 的对象&#xff0c;然后继续执行下面的代码&#xff0c;但uni.request的 success 回调…

ComfyUI 安装和入门

目录 AnimateDiff for ComfyUI ComfyUI 入门教程 什么是ComfyUI&#xff1f; windows安装教程&#xff1a; 安装&#xff1a;stable-diffusion-webui 组件技巧学习 AnimateDiff for ComfyUI GitHub - ArtVentureX/comfyui-animatediff: AnimateDiff for ComfyUI 生成动画…

Spring Boot 笔记 006 创建接口_注册

1.1 由于返回数据都是以下这种格式&#xff0c;那么久再编写一个result实体类 报错了&#xff0c;原因是没有构造方法 可以使用lombok的注解自动生成&#xff0c;添加无参的构造器和全参的构造器 package com.geji.pojo;import lombok.AllArgsConstructor; import lombok.NoArg…

Transformer实战-系列教程16:DETR 源码解读3(DETR类)

&#x1f6a9;&#x1f6a9;&#x1f6a9;Transformer实战-系列教程总目录 有任何问题欢迎在下面留言 本篇文章的代码运行界面均在Pycharm中进行 本篇文章配套的代码资源已经上传 点我下载源码 DETR 算法解读 DETR 源码解读1&#xff08;项目配置/CocoDetection类&#xff09; …

【MySQL】操作库 —— 库的操作 -- 详解

一、增删数据库 1、创建数据库 create database db_name; 本质就是在 /var/lib/mysql 创建一个目录。 说明&#xff1a; 大写的表示关键字。[ ] 是可选项。CHARACTER SET&#xff1a;指定数据库采用的字符集。COLLATE&#xff1a;指定数据库字符集的校验规则。 2、数据库删除…

Linux第51步_移植ST公司的linux内核第3步_添加修改设备树

1、设备树文件的路径 1)、创建linux中的设备树头文件 在“my_linux/linux-5.4.31/arch/arm/boot/dts/”目录中&#xff0c;以“stm32mp15xx-edx.dtsi”为蓝本&#xff0c;复制一份&#xff0c;并命名为 “stm32mp157d-atk.dtsi”&#xff0c;这就是我们开发板的设备树头文件。…

【stomp实战】Springboot+Stomp协议实现聊天功能

本示例实现一个功能&#xff0c;前端通过websocket发送消息给后端服务&#xff0c;后端服务接收到该消息时&#xff0c;原样将消息返回给前端。前端技术栈htmlstomp.js&#xff0c;后端SpringBoot 前端代码 关于stomp客户端的开发&#xff0c;如果不清楚的&#xff0c;可以看…

机器学习10-特征缩放

特征缩放的目的是确保不同特征的数值范围相近&#xff0c;使得模型在训练过程中更加稳定&#xff0c;加速模型收敛&#xff0c;提高模型性能。具体而言&#xff0c;零均值和单位方差的目标有以下几点好处&#xff1a; 1. 均值为零&#xff08;Zero Mean&#xff09;&#xff1a…

15 ABC基于状态机的按键消抖原理与状态转移图

1. 基于状态机的按键消抖 1.1 什么是按键&#xff1f; 从按键结构图10-1可知&#xff0c;按键按下时&#xff0c;接点&#xff08;端子&#xff09;与导线接通&#xff0c;松开时&#xff0c;由于弹簧的反作用力&#xff0c;接点&#xff08;端子&#xff09;与导线断开。 从…

【开源】SpringBoot框架开发天沐瑜伽馆管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 瑜伽课程模块2.3 课程预约模块2.4 系统公告模块2.5 课程评价模块2.6 瑜伽器械模块 三、系统设计3.1 实体类设计3.1.1 瑜伽课程3.1.2 瑜伽课程预约3.1.3 系统公告3.1.4 瑜伽课程评价 3.2 数据库设计3.2.…

牛客周赛 Round 32 F.小红的矩阵修改【三进制状态压缩dp】

原题链接&#xff1a;https://ac.nowcoder.com/acm/contest/75174/F 时间限制&#xff1a;C/C 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C 262144K&#xff0c;其他语言524288K 64bit IO Format: %lld 题目描述 小红拿到了一个字符矩阵&#xff0c;矩阵中仅包含&q…

java 执行方式和类加载过程

java默认属于混合执行&#xff1a; 编译和解释并存 java先进行解释执行&#xff0c;遇到多次重复的代码会把它编程成可执行文件&#xff0c;方便下次直接执行。 可以通过VM参数来修改执行方式。 类加载过程

Nacos、Eureka、Zookeeper、Consul对比

开发中&#xff0c;经常需要对微服务进行管理&#xff0c;所以需要引入一些服务治理的中间件&#xff0c;用于注册、发现服务&#xff0c;常见的服务治理中间件为 服务治理中间件 【1】Nacos 【2】Eureka 【3】Zookeeper 【4】Consul&#xff08;Consul 所在的 HashiCorp 公司…

从完成[flutter竖向显示文字]到对实现方式[Rich Text和Text Span]的一些整理

前言 完成的需求是竖向显示文字&#xff0c;而已有的RotatedBox虽然可以让文字内部控件进行指定角度的旋转&#xff0c;但是不能保持文字仍正常显示&#xff08;它会因为旋转横着&#xff09;&#xff0c;遂尝试Rich Text和Text Span的方式&#xff0c;这两个我曾在android有略…

红队笔记Day2 -->上线不出网机器

今天就来讲一下在企业攻防中如何上线不出网的机器&#xff01;&#xff01; 1.基本网络拓扑 基本的网络拓扑就是这样 以下是对应得的P信息&#xff0c;其中的52网段充当一个内网的网段&#xff0c;而111充当公网网段 先ping一下&#xff0c;确保外网ping不通内网&#xff0c;内…

文档类图像的智能识别,百度、阿里、华为腾讯开放接口

文档类图像的智能识别是指利用人工智能技术对文档图像进行自动识别和信息提取。在我国&#xff0c;百度、阿里、华为和腾讯等科技巨头都提供了相应的开放接口&#xff0c;方便开发者集成和使用文档类图像识别功能。以下是这些公司提供的相关开放接口&#xff1a; 1. 百…