検索
ホームページバックエンド開発PHPチュートリアルjavascript - AJAX是怎么样实现异步的呢?

AJAX的方法源码我看过,就是AJAX方法里面调用一个回调,先执行AJAX方法再执行回调,这跟普通的的引用函数 有什么区别呢?那么AJAX的异步回调在体验在哪里;

回复内容:

AJAX的方法源码我看过,就是AJAX方法里面调用一个回调,先执行AJAX方法再执行回调,这跟普通的的引用函数 有什么区别呢?那么AJAX的异步回调在体验在哪里;

上面几位真是所答非所问。
首先浏览器的js引擎是单线程的,执行一个耗时操作必定阻碍线程后续代码的执行(比如等待网络请求的响应)。一些语言采用了开一个子线程并把耗时操作放到子线程去执行的办法解决了这个问题。
js引擎本身不支持多线程,但是浏览器基本上都有三个线程:js引擎线程、事件触发线程、http请求线程。后两个线程在触发后会把对应的回调函数放到js引擎线程的执行队列中进行排队等待,只要js引擎线程空闲就会依次执行加入到队列中的回调函数。当然这些回调函数的执行依然是阻碍线程的。

页面无刷新进行数据请求,返回数据通过js操作DOM,用户体验良好;单纯调用js函数仅对前端有操作,没有与服务器的交互;AJAX是组合技术,提升用户体验,不必每次请求都刷新整个页面,即js操作dom进行局部刷新

在我看来本质上没有区别,一个传入函数,一个是类似面向对象中我多态覆盖(执行默认或者自定义覆盖的)

  1. 传引用
    比如:
    // 获取用户数据
    function getDate() {
    }

    // 登陆
    function login(cb) {

    <code>   // 登陆逻辑....
       // 登陆成功后执行回调引用
       if (cb && typeof cb === 'function') {
           cb();
       }</code>

    }

    login(getDate);

  2. ajax内部可能实现(不确保是这样的,只是模拟一下)

    function XMLHttpRequest() {
    }

    // 可以有默认的也可以没有,没有在send回调执行时判断一下就行了
    XMLHttpRequest.prototype.onreadystatechange = function () {};

    XMLHttpRequest.prototype.get = function (url) {

    <code>   this.url = url;</code>

    };

    XMLHttpRequest.prototype.send = function () {

    <code>   // 发送http请求,修改readyState等
       // 从this.url获取数据
       // 适时调用onreadystatechange, 没有默认onreadystatechange时判空
       if (this.onreadystatechange &&
           typeof this.onreadystatechange === 'function') {
           this.onreadystatechange();
       }</code>

    };

    var ajax = new XMLHttpRequest();
    ajax.get(url);
    ajax.onreadystatechange = function () {

    <code>   // 覆盖默认的,或者没有默认的话重新定义</code>

    };
    ajax.send();

你换成2G网络就能看出区别了 请求慢的时候下面的代码会继续执行 如果用同步 就干等着吧

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PHPでインターフェイスをどのように作成して使用しますか?PHPでインターフェイスをどのように作成して使用しますか?Apr 30, 2025 pm 03:40 PM

この記事では、PHPでインターフェイスを作成、実装、および使用する方法について説明し、コード組織と保守性の利点に焦点を当てています。

crypt()とpassword_hash()の違いは何ですか?crypt()とpassword_hash()の違いは何ですか?Apr 30, 2025 pm 03:39 PM

この記事では、PHPのCrypt()とpassword_hash()の違いについて、パスワードハッシュの違いについて説明し、最新のWebアプリケーションの実装、セキュリティ、および適合性に焦点を当てています。

PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?PHPのクロスサイトスクリプト(XSS)をどのように防ぐことができますか?Apr 30, 2025 pm 03:38 PM

記事では、入力検証、出力エンコード、およびOWASP ESAPIやHTML浄化器などのツールを使用して、PHPのクロスサイトスクリプト(XSS)を防止します。

PHPの自動装置は何ですか?PHPの自動装置は何ですか?Apr 30, 2025 pm 03:37 PM

PHPでのオートローディングは、必要に応じてクラスファイルを自動的にロードし、メモリの使用を削減し、コード組織を強化することでパフォーマンスを向上させます。ベストプラクティスには、PSR-4の使用とコードを効果的に整理することが含まれます。

PHPストリームとは何ですか?PHPストリームとは何ですか?Apr 30, 2025 pm 03:36 PM

PHPストリームは、一貫したAPIを介したファイル、ネットワークソケット、圧縮形式などのリソースの処理を統合し、複雑さを抽象化し、コードの柔軟性と効率を高めます。

PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?PHPを使用してアップロードできるファイルの最大サイズはどれくらいですか?Apr 30, 2025 pm 03:35 PM

この記事では、PHPでファイルアップロードサイズの管理を管理し、2MBのデフォルト制限とPHP.ini設定を変更してそれを増やす方法に焦点を当てています。

PHPのめまいの種類とは何ですか?PHPのめまいの種類とは何ですか?Apr 30, 2025 pm 03:34 PM

この記事では、PHP 7.1で導入されたPHPのヌル可能なタイプについて説明し、変数またはパラメーターが指定されたタイプまたはnullのいずれかを可能にします。読みやすさの改善、タイプの安全性、明示的な意図などの利点を強調し、宣言する方法を説明します

unset()とlink()関数の違いは何ですか?unset()とlink()関数の違いは何ですか?Apr 30, 2025 pm 03:33 PM

この記事では、プログラミングのunset()とlink()関数の違いについて説明し、目的とユースケースに焦点を当てています。 unset()はメモリから変数を削除しますが、link()はファイルシステムからファイルを削除します。どちらもEFFECにとって重要です

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター