要避免的 fetch() 和 XMLHttp 错误

要避免的 fetch() 和 xmlhttp 错误

可悲的是,我没有避免这些错误。我希望这可以帮助其他人在尝试更新网页而不完全下载新版本时避免它们。我最终得到的代码似乎有效:

async function fetchdbsingle(url, str) {  const datatosend = str;  console.log('fetchdbsingle: ' + str);  try {    const response = await fetch(url, {      method: 'post',      headers: { 'content-type': 'application/x-www-form-urlencoded' },      body: datatosend    });    if (!response.ok) {      throw new error('network response was not ok');    }    const data = await response.json();    return data;  } catch (error) {    console.error('error fetching data:', error);    throw error; // re-throw the error to be handled by the caller  }}

await 在异步函数内工作,以确保数据在尝试访问之前已到达。如果您需要从普通代码调用异步函数,语法为 .then:

fetchDbSingle(url, str).then(data => {  console.log("Received data:", data);  // Use the data here}).catch(error => {  console.error("Error fetching data:", error);}); 

如果您尝试在不使用此特殊语法的情况下访问数据,则数据将是未定义的,因为您是在数据到达之前访问它。

如果您尝试访问标记位置之外的数据,它将是未定义的。

在我的程序中,fetch() 正在调用读取数据库的 php 脚本。

这里有一些警告,对于有经验的人来说可能毫无意义,但我希望我早点知道:

请注意,php 将通过 echo 发送数据,在这种情况下,echo 不会出现在屏幕上。确保您的 php 文件仅包含 php 代码;没有 html。如果它包含 html,则返回的数据将包含所有 html,这将非常混乱。 确保 php 文件(及其包含的任何文件)只有一个 echo 语句。 (哦,并检查任何包含的文件中的 html 或 echo)json_encode 将通过 echo 发送的内容。你可能想要 javascript json 解析它以使其成为 javascript 数组,但这不是必需的。

如果有人有兴趣知道我为什么提到上述警告,我可以写一篇文章,介绍我所犯的错误以及我如何花了一周的时间来纠正这些错误,然后你就可以咯咯笑并感到优越。

以上就是要避免的 fetch() 和 XMLHttp 错误的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月9日 21:33:28
下一篇 2025年12月9日 21:33:41

相关推荐

  • 如何在 Laravel 中处理大型数据集而不耗尽内存

    如何在 laravel 中处理大型数据集而不耗尽内存 在 laravel 中处理大量数据时,经常会遇到应用程序内存不足等问题。当尝试一次将数千(甚至数百万)条记录加载到内存中时,可能会发生这种情况。然而,laravel 提供了一些有用的方法来帮助您以较小的块处理数据,从而节省内存并使应用程序运行得更…

    2025年12月9日
    000
  • 创建专注的领域应用程序 Symfony 方法(保存实体)

    介绍 在本系列的第三篇文章中,我们将创建一个准备好从我们在本系列第一篇文章中创建的 dto 持久保存到数据库的实体。 将 userinputdto 转换为实体 从本节开始,我们假设我们正在使用原则与数据库进行通信,并且我们的 user 实体如下所示: #[ormentity(repositorycl…

    2025年12月9日
    000
  • Web 图像:完美(自动)调整大小和转换

    几乎每个前端开发人员都知道,我们需要在不影响质量的情况下向用户提供尽可能小的图像。我们都知道如何实现这一目标。但这是一件没人喜欢做的苦差事。同样从商业角度来看,这需要时间,而时间就是金钱。所以,“足够好”就够了。 让我分享一下我们如何改进和自动化完美图像交付,而不会给开发人员带来更多工作。 通常是如…

    2025年12月9日
    000
  • 初学者提高编程逻辑的 5 个技巧

    编程方法的5个步骤是什么?如何才能擅长编程逻辑?编程逻辑的基础是什么?初学者应该如何开始编程? 想要找到这些问题的答案吗?请继续阅读。 计算机系统中的一组规则,也称为编程逻辑,指定了某些组件的放置顺序,以使计算机硬件能够执行特定任务。换句话说,编程逻辑是以系统的方式应用规则来产生可行的结果。 编程逻…

    2025年12月9日
    100
  • PHPStan:通过静态分析提高 PHP 代码质量

    在动态类型盛行的 php 生态系统中,管理代码质量并确保无错误开发可能具有挑战性。 phpstan 是一款专为 php 定制的静态分析工具,旨在帮助开发人员在运行代码之前捕获错误和潜在问题。通过静态分析,phpstan 允许开发人员通过在开发早期捕获错误来编写更可靠、可维护和健壮的代码。在这篇文章中…

    2025年12月9日
    000
  • 如何在 Laravel 中包含 JavaScript 适用于所有场景的分步指南

    如何在 laravel 11 中包含 javascript:适用于所有场景的分步指南 在 laravel 11 中,向项目添加 javascript 变得轻而易举,这要归功于默认的资源捆绑器 vite。以下是如何为各种场景设置 javascript,从全局包含到特定视图中的条件加载。 1. 在所有文…

    2025年12月9日
    000
  • Laravel 观察者:应用程序生命周期中的沉默忍者

    简介 想象一下,每当您在网站上提交表单时,一个隐形助手就会进来并再次检查所有内容。添加更多详细信息,甚至无需您费力即可发送一封欢迎信。 laravel 观察者就像默默工作的幕后助手。而且它的功能强大,可以在您需要时处理所有任务。在这篇文章中,我们将深入探讨观察者在 laravel 中的工作方式,以及…

    2025年12月9日
    000
  • 如何用php代码建表

    如何在 PHP 中使用 MySQL 创建表?连接到 MySQL 数据库。编写 CREATE TABLE 语句,指定新表及其列的结构。使用 mysqli_query() 函数执行 CREATE TABLE 语句。 如何在 PHP 中使用 MySQL 创建表 在 PHP 中使用 MySQL 创建表,需要…

    2025年12月9日
    000
  • 如何搭建nginx php

    搭建 Nginx + PHP 服务器共需要 6 个步骤:1. 安装 Nginx;2. 安装 PHP;3. 安装 PHP-FPM Nginx 模块;4. 配置 Nginx,创建配置文件并设置监听端口、服务器名称、根目录、文件查找顺序等;5. 配置 PHP,调整 PHP-FPM 池设置,包括监听端口、用…

    2025年12月9日
    000
  • php中不允许使用关键字来为变量命名吗

    PHP不允许使用关键字作为变量名,因为关键字是预先定义的保留字,用于特定语法目的,如abstract、case、const、default等。而魔法方法__call()和__get()允许在特殊情况下使用关键字,但对于常规变量命名,建议避免使用关键字,以防止编译时错误和潜在冲突。 PHP中允许使用关…

    2025年12月9日
    000
  • 前端和企业 PHP 开发者,哪个 IDE 更适合你?

    php ide 比较 对于偏向于前端和企业发展的 PHP 开发人员,这里推荐几个好用且专业的 IDE 选项: PHPStorm PHPStorm 是 JetBrains 开发的一款强大的 PHP IDE,深受开发人员的喜爱。它提供了许多高级功能,包括: 智能代码完成代码重构和重构版本控制集成调试和性…

    2025年12月9日
    000
  • New in EasyAdmin: Pretty URLs

    easyadmin 最受欢迎的功能刚刚在 4.14.0 版本中推出。 从第一天开始,easyadmin 就使用查询字符串参数来传递必要的渲染后端页面的信息。这种方法创建的 url 如下: https://example.com/admin?crudaction=edit&crudcontro…

    2025年12月9日
    100
  • 如何在 PHP CodeIgniter 中生成 Pdf sing *dompdf*

    第 1 步:创建数据库表在 mysql 数据库中创建用户表: create table users ( id int auto_increment primary key, name varchar(50) not null, surname varchar(50) not null, email …

    2025年12月9日
    000
  • Lithe Crypt:简化 PHP 应用程序中的加密

    lithe crypt 是一个简单的 php 加密和解密实用程序,旨在与 lithe 框架配合使用。它利用 aes-256-cbc 算法进行安全数据处理。 安装 要安装 lithe crypt 软件包,您可以使用 composer。如果您尚未安装,请确保 composer 在您的系统上可用。然后在项…

    2025年12月9日
    000
  • Lithe Crypt:简化 PHP 应用程序中的加密技术

    lithe crypt 是 php 中的一个简单的加密和解密实用程序,旨在与 lithe 框架配合使用。它使用 aes-256-cbc 算法进行安全数据处理。 安装 要安装 lithe crypt 软件包,您可以使用 composer。如果您尚未安装,请确保 composer 在您的系统上可用。然后…

    2025年12月9日
    000
  • Lithe Mail:简化 PHP 应用程序中的电子邮件发送

    你好,社区!今天,我想向您介绍 lithe mail,这是一个简化在 php 应用程序中通过 smtp 发送电子邮件的软件包。它提供与环境变量的灵活集成,使配置变得容易。让我们看看如何设置并在您的项目中使用它。 安装 您可以通过 composer 安装该软件包。在终端中运行以下命令: compose…

    2025年12月9日
    000
  • 使用 PHP 集成 Lloyds 支付卡:Cardnet 托管支付页面(连接解决方​​案)

    介绍 集成安全可靠的支付网关对于电子商务业务至关重要。劳埃德银行的 cardnet® 托管支付页面解决方案 connect 提供了一种安全的交易处理方式。客户将被重定向到劳埃德托管的页面以完成交易,然后返回您的网站。以下是您如何设置它、将其与 php 集成并为您的用户提供无缝体验的方法。 lloyd…

    2025年12月9日
    000
  • 如何使用 PHP 从 MySQL 数据库中获取名单并将其显示到前端?

    从 mysql 显示名单到前端的 php 实现 要从 mysql 数据库中将名单数据显示到前端,需要遵循以下步骤: 1. 建立数据库连接 使用 mysql_connect() 函数连接到 mysql 数据库,并选择要从中获取数据的数据库。 立即学习“PHP免费学习笔记(深入)”; 2. 执行查询 使…

    2025年12月9日
    100
  • PHP 中的机器学习:使用 Rubix ML 构建新闻分类器

    介绍 机器学习无处不在——推荐电影、标记图像,现在甚至对新闻文章进行分类。想象一下如果您可以在 php 中做到这一点!借助 rubix ml,您可以以简单易懂的方式将机器学习的强大功能引入 php。本指南将引导您构建一个简单的新闻分类器,将文章分类为“体育”或“技术”等类别。最后,您将拥有一个工作分…

    2025年12月9日
    000
  • a 标签 onclick 事件无法跳转,问题出在哪?

    a 标签中的 onclick 不能正常跳转的问题 你在 onclick 事件中使用 javascript 设置了 a 标签的 href 属性,希望它跳转到特定的 url。然而,它似乎没有正常跳转。 原因及解决方案 检查一下你的事件处理函数是否正确。你使用的是 jscript,而正确的 javascr…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信