Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537 Warning: error_log(/data/www/wwwroot/hmttv.cn/caches/error_log.php): failed to open stream: Permission denied in /data/www/wwwroot/hmttv.cn/phpcms/libs/functions/global.func.php on line 537
有兩個頁面parent.html和child.html,在parent頁面里面通過window.open打開了child頁面,child頁面執行完代碼之后想要刷新parent頁面,然后立即查看到修改后的效果,那么我們就要在child里面直接能夠刷新parent頁面,這樣就可以實現這樣的效果。
1.1打開了parent.html頁面
1.2在parent頁面打開了child頁面
1.3child頁面點擊確定按鈕之后刷新了父頁面parent
2 parent.html內容:
<!DOCTYPE html>
<html>
<head>
<title>parents</title>
<meta charset="UTF-8">
<script language="javascript" type="text/javascript">
function openWin() {
window.open('child.html', '_blank','width=500,height=400,top=200,left=400');
}
//定義callback方法,用于回調
function callback() {
refreshWin();
}
//刷新當前頁面
function refreshWin() {
//調用刷新頁面的方法,刷新當前頁面,結果會再次彈出222
window.location.reload();
}
//剛記載的時候彈出222
function show(){
alert(222);
}
</script>
</head>
<body onload="show()">
<input id="btnAdd" type="button" onclick="openWin();" value="添加" />
</body>
</html>
3 child.html內容:
<!DOCTYPE html>
<html>
<head>
<title>child</title>
<meta charset="UTF-8">
<script language="javascript" type="text/javascript">
function formSubmit(){
window.opener.callback();//上述執行完成后,調用打開頁面的callback方法,此處是調用主頁面的callback方法
window.close();//當前頁面關閉
}
</script>
</head>
<body>
<input id="onSub" type="button" onclick="formSubmit();" value="確定">
</body>
</html>
4 通過這樣的操作很容易在子頁面操作父頁面所有的方法,感覺很方便,整理一下供大家參考。
歡迎關注我的頭條號,謝謝大家!
天分享一個實現頁面自動檢測更新,而且不需要動服務端代碼的方法,比較取巧,在非覆蓋式發布的情況下可以簡單使用。
有部分運營是不刷新頁面的,當我們前端資源更新了,他可能還在使用老的資源。
目標是希望在我們前端資源更新的時候提示用戶有資源更新,然后刷新頁面獲取最新的前端資源。
一個適合非覆蓋式發布的前端應用的自動檢測更新方法。
覆蓋式發布 | 前后兩次發布的資源沒有差異,js 資源也不使用 hash 進行區分 |
非覆蓋式發布 | 前后兩次發布的資源會有差異,比如體現在 js 資源帶上 hash 或者發布的版本號 |
所以,我們以構建之后 js 資源帶 hash 的頁面為例,如果有新的發布,那么 js 資源的鏈接就會發生改變,通過比較前后兩次的資源地址來判斷頁面是否發布。
構建之后是帶 hash 的資源文件
Web項目開發過程中,實現頁面局部刷新和實時數據更新是一項常見的需求。Ajax(Asynchronous JavaScript and XML)技術為此提供了完美的解決方案,它能在不重新加載整個頁面的情況下,通過JavaScript發送異步HTTP請求,獲取服務器端數據并更新頁面內容。本文將以Python Flask框架為例,介紹如何利用Ajax實現頁面的一步刷新,并附帶具體代碼示例。
首先,我們需要在Flask后端設置一個處理Ajax請求的路由和視圖函數,該函數返回需要更新的數據:
from flask import Flask, jsonify
app = Flask(__name__)
@app.route('/get_updates', methods=['GET'])
def get_updates():
# 假設此處是從數據庫或其它來源獲取最新數據
latest_data = fetch_latest_data()
return jsonify(latest_data)
在前端HTML中,我們需要一個元素來展示從服務器獲取的數據,并編寫JavaScript腳本來發起Ajax請求:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function() {
function updateData() {
$.ajax({
url: '/get_updates',
type: 'GET',
success: function(response) {
// 更新頁面元素
$('#data-display').html(response.some_field);
},
error: function(xhr, status, error) {
console.error('Failed to load data:', error);
}
});
}
// 初始加載
updateData();
// 定時刷新(例如每5秒一次)
setInterval(updateData, 5000);
});
</script>
</head>
<body>
<div id="data-display"></div>
</body>
</html>
上述代碼中,我們使用了jQuery庫簡化Ajax請求的處理。$.ajax函數用于發送GET請求到’/get_updates’路由,當請求成功時,服務器返回的JSON數據會被用來更新頁面上指定的HTML元素。
在實際應用場景中,除了定期刷新數據外,還可以根據特定事件觸發Ajax請求,比如用戶點擊按鈕、滾動頁面等:
// 假設有一個按鈕,點擊時獲取更新
$('#refresh-btn').click(function() {
updateData();
});
通過整合Flask后端與前端Ajax技術,我們可以輕松實現Web頁面的實時刷新與局部更新,大大提升了用戶體驗和應用的響應速度。
關注我,手把手帶你快速入門Python Web編程!
*請認真填寫需求信息,我們會在24小時內與您取得聯系。