如题,用js向php发送一个请求并加载响应到当前页面的时候,如何避免重写是覆盖当前页面;
具体情况是这样的:
js:
var navLst = {}; var reqInfo = {}; reqInfo['reqNav'] = true; reqInfo['reqSin'] = 'qtrfss'; //more limt options would be added var reqSent= JSON.stringify(reqInfo); var xhr = null; if(window.XMLHttpRequest){ xhr = new XMLHttpRequest(); }else{ xhr = ActiveXObject('Microsoft.XMLHttp'); } xhr.open('POST', '/themes/ticket/model/echoNav.php',true); xhr.onreadystatechange=function(){ if(xhr.readyState == 4) { if(xhr.status == 200) { try{ var resp = eval('('+ xhr.responseText +')'); listMenu(resp); }catch(e){ listMenu(e); } } else { //undo } } }; xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr.send('reqSent='+reqSent);
/themes/ticket/model/echoNav.php返回的是一个数组字符串化的json;
然后获取到了menlist,重写的时候整个页面只剩下menulist了。。。
listmenu:
function listMenu(menuLst){
//var menuLst = ['Sci-Fi','home','wiki'];//menu lst should come from php var nav = ''; var navIE = ''+ ''+ ''+ ''+ ''+ ''+ ''+ ''+ ''+ ''+ ' '+ ''+ ''; var navStyle = '';//stylesheet's url nav +=navIE; nav +=navStyle; nav +=''; document.write(nav); var navUl = document.createElement('ul'); navUl.id = 'onav_bar'; var navLst = '' for (var i=0 ;i <= menuLst.length - 1; i++) { var navLi = document.createElement('li'); var achor = document.createElement('a'); if(i == 0){ navLi.className = 'onav_top onav_logo'; achor.setAttribute('href','#'); var spanX = document.createElement('span'); spanX.className = 'onav_yellow'; spanX.innerHTML = 'Sci-Fi'; achor.appendChild(spanX); var spanY = document.createElement('span'); spanY.className = 'onav_white'; spanY.innerHTML = '.Net'; achor.appendChild(spanY); }else{ navLi.className = 'onav_top'; achor.setAttribute('href','#'); achor.setAttribute('target','_blank'); achor.setAttribute('title',menuLst[i]); achor.innerHTML = menuLst[i]; } navLi.appendChild(achor); navUl.appendChild(navLi); }; var navDiv = document.getElementById('onav_wrapper'); navDiv.appendChild(navUl); //need to be brief var oAhor = document.getElementById('onav_bar').getElementsByTagName('a'); for (i=0; i<oAhor.length; i++) { var testAttr = oAhor[i].parentNode.getAttribute('class'); if (oAhor[i].href == window.location) { if (testAttr === null) { oAhor[i].parentNode.setAttribute('class', 'onav_active'); } else{ oAhor[i].parentNode.setAttribute('class', testAttr + ' onav_active'); } } } }
解决方案:
是 document.write(nav);
, DOM加载完成后再用document.write()
方法会覆盖以前内容。测试一下,把其中函数中的方法换成document.write('')

TheSecretTokeEpingAphp-PowerEdwebSiterUnningSmoothlyShyunderHeavyLoadInVolvOLVOLVOLDEVERSALKEYSTRATICES:1)emplactopCodeCachingWithOpcachingWithOpCacheToreCescriptexecution Time,2)使用atabasequercachingCachingCachingWithRedataBasEndataBaseLeSendataBaseLoad,3)

你應該關心DependencyInjection(DI),因為它能讓你的代碼更清晰、更易維護。 1)DI通過解耦類,使其更模塊化,2)提高了測試的便捷性和代碼的靈活性,3)使用DI容器可以管理複雜的依賴關係,但要注意性能影響和循環依賴問題,4)最佳實踐是依賴於抽象接口,實現鬆散耦合。

是的,優化papplicationispossibleandessential.1)empartcachingingcachingusedapcutorediucedsatabaseload.2)優化的atabaseswithexing,高效Quereteries,and ConconnectionPooling.3)EnhanceCodeWithBuilt-unctions,避免使用,避免使用ingglobalalairaiables,並避免使用

theKeyStrategiestosigantificallyBoostPhpaPplicationPerformenCeare:1)UseOpCodeCachingLikeLikeLikeLikeLikeCacheToreDuceExecutiontime,2)優化AtabaseInteractionswithPreparedStateTementStatementStatementAndProperIndexing,3)配置

aphpdepentioncontiveContainerIsatoolThatManagesClassDeptions,增強codemodocultion,可驗證性和Maintainability.itactsasaceCentralHubForeatingingIndections,因此reducingTightCightTightCoupOulplingIndeSingantInting。

選擇DependencyInjection(DI)用於大型應用,ServiceLocator適合小型項目或原型。 1)DI通過構造函數注入依賴,提高代碼的測試性和模塊化。 2)ServiceLocator通過中心註冊獲取服務,方便但可能導致代碼耦合度增加。

phpapplicationscanbeoptimizedForsPeedAndeffificeby:1)啟用cacheInphp.ini,2)使用preparedStatatementSwithPdoforDatabasequesies,3)3)替換loopswitharray_filtaray_filteraray_maparray_mapfordataprocrocessing,4)conformentnginxasaseproxy,5)

phpemailvalidation invoLvesthreesteps:1)格式化進行regulareXpressecthemailFormat; 2)dnsvalidationtoshethedomainhasavalidmxrecord; 3)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版
視覺化網頁開發工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器