页面加载后的Ajax调用
Ajax call after page load
我正在尝试构建一个搜索页面,用户将文本输入到搜索框中,然后根据搜索生成页面。我遇到了时间问题,因为JS试图编辑页面上的值后,空白搜索页面正在加载。
$.ajax({
type: 'GET',
url: '/index.php/content/generate_search',
data: {
search: input.val()
},
beforeSend: function() {
window.location.href = '/index.php/content/search';
},
success: function() {
$('.hero h1').text(input.val());
}
});
要检查DOM是否已完全加载,需要执行许多步骤,同时考虑所有浏览器。(我在jQuery源代码中找不到实现,但我会返回一个链接)。
由于您已经在使用jQuery,因此最简单也是最好的方法是:
$( function() {
// your code here
} );
这是的简写
$( document ).ready( function() {
// your code here
} );
编辑
好的,所以正如我所承诺的,我带着document.ready
的实现回来了。你可以在这里的GitHub上找到它。这是该文件当前版本的永久链接。
试试这个:
$(document).ready(function(){
//Your code
});
onload用于在页面加载上执行代码
window.onload = function() {
// your code
};
此代码:
beforeSend: function() { window.location.href = "/index.php/content/search"; },
…导致浏览器在发送Ajax请求之前离开页面并加载新页面。
因此,Ajax请求被取消。如果没有,那么就没有JavaScript在等待接收响应。
如果您想访问/index.php/content/search
然后启动Ajax请求,那么启动Ajax请求的JavaScript必须在/index.php/content/search
上。您刚刚离开的页面无法在下一页运行JavaScript。
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作