如题,用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-poweredwebsiterunningsmoothlyunderheavyloadinvolvesseveralkeystrategies:1)ImplementopcodecachingwithOPcachetoreducescriptexecutiontime,2)UsedatabasequerycachingwithRedistolessendatabaseload,3)LeverageCDNslikeCloudflareforservin

You should care about DependencyInjection(DI) because it makes your code clearer and easier to maintain. 1) DI makes it more modular by decoupling classes, 2) improves the convenience of testing and code flexibility, 3) Use DI containers to manage complex dependencies, but pay attention to performance impact and circular dependencies, 4) The best practice is to rely on abstract interfaces to achieve loose coupling.

Yes,optimizingaPHPapplicationispossibleandessential.1)ImplementcachingusingAPCutoreducedatabaseload.2)Optimizedatabaseswithindexing,efficientqueries,andconnectionpooling.3)Enhancecodewithbuilt-infunctions,avoidingglobalvariables,andusingopcodecaching

ThekeystrategiestosignificantlyboostPHPapplicationperformanceare:1)UseopcodecachinglikeOPcachetoreduceexecutiontime,2)Optimizedatabaseinteractionswithpreparedstatementsandproperindexing,3)ConfigurewebserverslikeNginxwithPHP-FPMforbetterperformance,4)

APHPDependencyInjectionContainerisatoolthatmanagesclassdependencies,enhancingcodemodularity,testability,andmaintainability.Itactsasacentralhubforcreatingandinjectingdependencies,thusreducingtightcouplingandeasingunittesting.

Select DependencyInjection (DI) for large applications, ServiceLocator is suitable for small projects or prototypes. 1) DI improves the testability and modularity of the code through constructor injection. 2) ServiceLocator obtains services through center registration, which is convenient but may lead to an increase in code coupling.

PHPapplicationscanbeoptimizedforspeedandefficiencyby:1)enablingopcacheinphp.ini,2)usingpreparedstatementswithPDOfordatabasequeries,3)replacingloopswitharray_filterandarray_mapfordataprocessing,4)configuringNginxasareverseproxy,5)implementingcachingwi

PHPemailvalidationinvolvesthreesteps:1)Formatvalidationusingregularexpressionstochecktheemailformat;2)DNSvalidationtoensurethedomainhasavalidMXrecord;3)SMTPvalidation,themostthoroughmethod,whichchecksifthemailboxexistsbyconnectingtotheSMTPserver.Impl


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Atom editor mac version download
The most popular open source editor

Notepad++7.3.1
Easy-to-use and free code editor

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

SublimeText3 Mac version
God-level code editing software (SublimeText3)

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
