>  기사  >  웹 프론트엔드  >  모든 ajax가 실행되고 페이지가 로드됩니다.

모든 ajax가 실행되고 페이지가 로드됩니다.

巴扎黑
巴扎黑원래의
2017-07-03 11:03:333752검색

jquery ajax&load 메소드를 사용하면 js 효과가 표시되지 않거나 로딩 후 페이지의 ajax 릴레이아웃으로 인해 효과 오류가 발생합니다.

해결책: 불완전한 실행으로 인해 발생하는 최종 오류를 방지하려면 ajax가 게시 또는 로드한 후에 메서드를 실행해야 합니다.

그런 다음 먼저 로드 메서드 정의를 살펴보세요.

jQuery ajax - load() 方法

jQuery Ajax 参考手册
实例

使用 AJAX 请求来改变 p 元素的文本:

$("button").click(function(){
  $("p").load('demo_ajax_load.txt');
});

亲自试一试

您可以在页面底部找到更多 TIY 实例
定义和用法

load() 方法通过 AJAX 请求从服务器加载数据,并把返回的数据放置到指定的元素中。

注释:还存在一个名为 load 的 jQuery 事件方法。调用哪个,取决于参数。
语法

load(url,data,function(response,status,xhr))

参数 	描述
url 	规定要将请求发送到哪个 URL。
data 	可选。规定连同请求发送到服务器的数据。
function(response,status,xhr) 	

可选。规定当请求完成时运行的函数。

额外的参数:

    response - 包含来自请求的结果数据
    status - 包含请求的状态("success", "notmodified", "error", "timeout" 或 "parsererror")
    xhr - 包含 XMLHttpRequest 对象

详细说明

该方法是最简单的从服务器获取数据的方法。它几乎与 $.get(url, data, success) 等价,不同的是它不是全局函数,并且它拥有隐式的回调函数。当侦测到成功的响应时(比如,当 textStatus 为 "success" 或 "notmodified" 时),.load() 将匹配元素的 HTML 内容设置为返回的数据。这意味着该方法的大多数使用会非常简单:

$("#result").load("ajax/test.html");

如果提供回调函数,则会在执行 post-processing 之后执行该函数:

$("#result").load("ajax/test.html", function() {
  alert("Load was performed.");
});

上面的两个例子中,如果当前文档不包含 "result" ID,则不会执行 .load() 方法。

如果提供的数据是对象,则使用 POST 方法;否则使用 GET 方法。
加载页面片段

.load() 方法,与 $.get() 不同,允许我们规定要插入的远程文档的某个部分。这一点是通过 url 参数的特殊语法实现的。如果该字符串中包含一个或多个空格,紧接第一个空格的字符串则是决定所加载内容的 jQuery 选择器。

我们可以修改上面的例子,这样就可以使用所获得文档的某部分:

$("#result").load("ajax/test.html #container");

如果执行该方法,则会取回 ajax/test.html 的内容,不过然后,jQuery 会解析被返回的文档,来查找带有容器 ID 的元素。该元素,连同其内容,会被插入带有结果 ID 的元素中,所取回文档的其余部分会被丢弃。

jQuery 使用浏览器的 .innerHTML 属性来解析被取回的文档,并把它插入当前文档。在此过程中,浏览器常会从文档中过滤掉元素,比如 <html>, <title> 或 <head> 元素。结果是,由 .load() 取回的元素可能与由浏览器直接取回的文档不完全相同。

注释:由于浏览器安全方面的限制,大多数 "Ajax" 请求遵守同源策略;请求无法从不同的域、子域或协议成功地取回数据。
更多实例
例子 1

加载 feeds.html 文件内容:

$("#feeds").load("feeds.html");

例子 2

与上面的实例类似,但是以 POST 形式发送附加参数并在成功时显示信息:

$("#feeds").load("feeds.php", {limit: 25}, function(){
  alert("The last 25 entries in the feed have been loaded");
});

例子 3

加载文章侧边栏导航部分至一个无序列表:

HTML 代码:

<b>jQuery Links:</b>
<ul id="links"></ul>

jQuery 代码:

$("#links").load("/Main_Page #p-Getting-Started li");


콜백 메서드가 있다는 것을 알았습니다. 훌륭합니다. 콜백에 나만의 메서드를 작성하면 Ajax 이후에 실행됩니다. 그 이후로:

$("#feeds").load("feeds.php", function(){
    fun();
});

하지만 질문이 있습니다. 둘 이상이면 어떻게 되나요? 하나씩 추가하시겠습니까? 또한 이 메서드가 실행되었는지 여부도 확인합니다. (...)

그래서: jquery 내장 판단을 찾은 다음 모두 완료된 후 실행합니다. 따라서:

	$("p").ajaxStop(function(){
		if (hash && !isGlobalHash) {
			$("#MfTit"+hash).trigger("click");
			isGlobalHash = true;
		}
	});

정의:

Instance

모두 AJAX 요청이 완료되면 프롬프트가 표시됩니다. 상자가 트리거됩니다:

$("p").ajaxStop(function(){
  alert("所有 AJAX 请求已完成");
});

물론 중지가 있으면 시작이 있습니다.

위 내용은 모든 ajax가 실행되고 페이지가 로드됩니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.