亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

javascript - 在方法里 window.location.href 不會立即跳轉,有什么方法解決

瀏覽:98日期:2023-05-13 09:28:30

問題描述

疑問:為何不是執行 location.href = 'http://www.aoyou183.cn/exit.html';, 而是執行了 window.location.href = ’http://www.baidu.com’; ?

有什么辦法執行完 getData(), 如果獲取數據失敗,則跳轉到 ../exit.html, 不再執行 gourl(); 方法呢?

補充:ajax里面的 async: false 是同步請求!!!,這個只是一個簡單的demo,實際上getData()方法后面可能有很多邏輯,但是如果getData()獲取數據失敗,就不讓程序再執行其他的方法,而且其他的方法不一定在同一個文件里面。

<!DOCTYPE html><html lang='en'><head> <meta charset='utf-8'></head><body> <p><h2>我是測試頁面,看我是否發生跳轉</h2></p> <script src='https://cdn.bootcss.com/jquery/1.9.0/jquery.min.js'></script> <script type='text/javascript'> $(function() {getData();gourl(); }); function getData() {var is_success = false;$.ajax({ type: 'GET', url: 'http://baike.baidu.com/api/openapi/BaikeLemmaCardApi?scope=103&format=json&appid=379020&bk_key=bug&bk_length=600', data: '', dataType: 'json', async: false, success: function(data) {if (data.status == 200) { is_success = true;} else { is_success = false;} }});if (!is_success) { location.href = 'http://www.aoyou183.cn/exit.html';} } function gourl() {console.log(’我被執行了’);window.location.href = ’http://www.baidu.com’; } </script></body></html>

問題解答

回答1:

那你可以在getData方法success后再回調gourl進行你要的邏輯處理另外 不清楚你的is_success是具體怎么判斷 因為有$ajax也有對應的error

回答2:

你的代碼相當于執行下面這兩句:

location.href = ’../exit.html’;location.href = ’http://www.baidu.com’;

這兩句連續執行的時候會跳轉后面這個地址

猜測是瀏覽器訪問第一個需要時間,還未成功,第二個跳轉又來了,所以就放棄第一次跳轉,執行第二次跳轉,類似在url里面快速輸入兩次地址一樣。

回答3:

gourl()函數不可以在前面調用,而應該放在Ajax的邏輯中間,在if邏輯后面添加 else{gourl();}即:

if (!is_success) {location.href = 'http://www.aoyou183.cn/exit.html'; }else {gourl(); }回答4:

題主的代碼可以理解為這樣:

<script type='text/javascript'> $(function() {getData(); }); function getData() {var is_success = false;$.ajax({ type: 'GET', url: 'http://baike.baidu.com/api/openapi/BaikeLemmaCardApi?scope=103&format=json&appid=379020&bk_key=bug&bk_length=600', data: '', dataType: 'json', async: false, success: function(data) {if (data.status == 200) { is_success = true;} else { is_success = false;} }, error: function() { ... }});if (!is_success) { location.href = 'http://www.aoyou183.cn/exit.html';}console.log(’我被執行了’);window.location.href = ’http://www.baidu.com’; } </script>

當代碼中有連續的兩個location.href的時候,會執行后面的跳轉,這個題主可以自己試一試。

另外,由于ajax是異步的,題主需要將if(!is_success)寫到ajax中的error中去,或者寫到success中的else判斷中,否則無論ajax是否成功,都會跳轉。gourl()同樣應該寫到success中。

此外,直接這樣的ajax應該會發生跨域錯誤的吧,建議使用代理或者其他方式解決跨域問題。

回答5:

手機碼的,是這個意思不?

$(function() { var dtd = $.Deferred(); dtd .done(function(){ console.log(’我被執行了’); window.location.href = ’http://www.baidu.com’; }) .fail(function(){ console.log(’我被拋棄了’); window.location.href = 'http://www.aoyou183.cn/exit.html'; }); $.get('http://baike.baidu.com/api/openapi/BaikeLemmaCardApi?scope=103&format=json&appid=379020&bk_key=bug&bk_length=600', 'json') .done(function(data) { if (data.status == 200) { dfd.resolve(); } else { dtd.reject(); } });});

主要是用jQ的promise,全部寫成異步,ajax的成功回調全部放在Deferred的done里(有多個也可以寫成數組),然后ajax的done里直接給個狀態就行了。

回答6:

既然getData和gourl有執行的關系,要么把gourl放到回調判斷 這個是可以適合異步的。如果是題主的同步,那么還可以

$(function() {getData();gourl(); });

直接在這里控制Gourl要不要執行也可以把?

回答7:

你的代碼邏輯有問題吧,ajax是異步的呀。gourl();這個函數不應該在那個地方調用。可以在ajax請求的成功或者失敗回調里調。看你的要求應該是在success里面調用。

標簽: JavaScript
主站蜘蛛池模板: 国产美女视频黄a视频免费全过程 | 青青艹视频在线 | 成人欧美精品久久久久影院 | 成人免费男女视频网站慢动作 | 欧美在线观看高清一二三区 | 免费大片网站 | 操操操综合 | 黄色自拍网站 | 极品销魂一区二区三区 | 国产一级做a爱免费观看 | 两个人做人爱视频免费 | 国产小视频在线观看www | 中文字幕高清在线 | 99精彩免费观看 | 久久久久久久九九九九 | 国产在线精彩视频 | 青青青国产精品国产精品久久久久 | 久久国产精品免费观看 | 爱综合网| 91在线播放国产 | 污污网站免费入口链接 | 国产精品成人嫩妇 | 午夜国产精品影院在线观看 | 高清无遮挡在线观看 | 国产在线精彩视频 | 欧美日韩在线观看一区 | 一区二区三区无码高清视频 | 日本大学生免费一级一片 | 亚洲日本韩国欧美 | 亚洲国产精品久久网午夜 | 日本三级韩国三级三级a级按摩 | 中文字幕第一页面 | 午夜高清性色生活片 | 中文精品久久久久国产不卡 | 日韩高清在线日韩大片观看网址 | 中文福利视频 | 久久爱www成人 | 手机国产日韩高清免费看片 | 欧美成人禁片在线观看俄罗斯 | 免费看黄网站在线 | 在线观看免费视频网站色 |