typeof window.onload=="function" JavaScript 1C

onload是属性还是函数,虽然明显是函数,但不知道怎么理解,希望能有正确解释和引用资料

5个回答

 console.log('onload' in window);//利用in运算符判断某对象是否拥有某属性

onload是window的属性,属性可以是函数,对象或者普通类型,不过标准用法就是函数,资源加载完毕后执行用的

onload属于文档加载的全局方法,和点击事件是一样的,当页面文档被加载后执行,javascript已经对它进行了封装,它的数据类型是Function型。希望对你有帮助。
你可以参考http://www.softwhy.com/forum.php?mod=viewthread&tid=6191。

个人理解,不喜勿喷!

window.onload = function(){ } ;一般这么用的,它是window对象的属性。
比如java中
class Window {

private int a ;

private B b ; //其他对象

}

只是在javascript中,函数==方法==对象.属性

js的函数写成了对象.属性的形式。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
这段代码,Ajax的功能无法实现
(getNewContent.js) function getNewContent(){ var request = getHTTPObject(); if(request){ request.open("GET","example.TXT",true); request.onreadystatechange = function(){ if(request.readyState==4){ var para = document.createElement("p"); var txt = document.createTextNode(request.responseText); para.appendChild(txt); document.getElementById("new").appendChild(para); } }; request.send(null); }else{ alert("Sorry,your browser doesn't support XMLHttpRequest"); } } addLoadEvent(getNewContent); (getHTTPObject.js) function getHTTPObject(){ if(typeof XMLHttpRequest == "undefined") XMLHttpRequest = function (){ try {return new ActiveXObject("Msxml2.XMLHTTP.6.0");} catch (e) { } try {return new ActiveXObject("Msxml2.XMLHTTP.3.0");} catch (e) { } try {return new ActiveXObject("Msxml2.XMLHTTP");} catch (e) { } return false; } return new XMLHttpRequest(); } (addLoadEvent.js) function addLoadEvent(func){ var oldFun = window.onload; if(typeof window.onload != 'function') { window.onload=func; }else{ window.onload = function(){ oldFun(); func(); } } } 窝把这三个js文件,用script加到html文件里,exmaple.txt,文档里面的文字没有显示在id为new的div里面,求大神帮忙,代码哪里出了问题。
html中引入的js为什么没反应啊?
``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Image Gallery</title> <link rel="stylesheet" type="text/css" href="../css/imggallery.css"> <!-- <link rel="stylesheet" type="text/css" href="../css/galleryLayOut.css"> --> <script src="../js/showPic.js"> </script> </head> <body> <h1>Image Gallery</h1> <ul id="imagegallery"> <li> <a href="../images/1.jpeg" title="a handsom boy">kanan</a> </li> <li> <a href="../images/2.jpg"title="a smart fish">fish</a> </li> <li> <a href="../images/3.jpg"title="a smart dog">dog</a> </li> <li> <a href="../images/4.jpg"title="a fine day">glass</a> </li> <img src="../images/placehold.jpg" alt="my placehold gallery"/> <p id="description">Choose an image.</p> </ul> </body> </html> addLoadEvent(prepareGallery); window.onload = function prepareGallery() { if(!document.getElementByTagName) return false; if(!document.getElementById) return false; if(!document.getElementById("imagegallery")) return false; var gallery = document.getElementById("imagegallery"); var links = gallery.getElementByTagName("a"); for(var i = 0;i < links.length; i++){ links[i].onclick = function(){ return showPic(this)?false:true; } } } function showPic(whichpic) { if(!document.getElementById("placehold")) return false; var source = whichpic.getAttribute("href"); var placehold = document.getElementById("placehold"); if(placehold.nodeName !="IMG") return false; placehold.setAttribute("src",source); if(document.getElementById("description")){ //若存在则更新,否则忽略 var text = whichpic.getAttribute("title") ? whichpic.getAttribute("title"):""; var description = document.getElementById("description"); if(description.firstChild.nodeType ==3){ description.firstChild.nodeValue = text; } } return true; } function addLoadEvent(func){ var oldonload = window.onload; if(typeof window.onload != 'function'){ window.onload = func; }else{ window.onload = function{ oldonload(); func(); } } } //本意是在本页面中看到连接的不同图片,但是这样还是跳转到了另一个窗口去了 //新手,谢谢指导。 ```
JS初学者一个小问题,求大神指教
``` <!DOCTYPE html > <html lang="en" > <head> <meta charset="utf-8" /> <title>这是啥?</title> <link rel="stylesheet" href="css/layout.css" media="screen" /> </head> <body> <h1>不知道啊</h1> <ul id="imagegallery"> <li> <a href="image/1.jpg" onclick="showPic(this); return false;" title="This is One">One</a> </li> <li> <a href="image/2.jpg" title="This is Two">Two</a> </li> <li> <a href="image/3.jpg" title="This is Three">Three</a> </li> <li> <a href="image/4.jpg" title="This is Four">Four</a> </li> </ul> <img id="placeholder" height="270" width="480" src="image/sb.jpg" alt="这到底是啥?"/> <p id="description">我也不知道啊</p> <script type="text/javascript" src="js/mdzz.js"></script> </body> </html> ``` ``` function showPic(whichpic) { if(!document.getElementById("placeholder")) return false; var source = whichpic.getAttribute("href"); var placeholder = document.getElementById("placeholder"); if(placeholder.nodeName != "IMG") return false; placeholder.setAttribute("src", source); if(document.getElementById("description")) { var text = whichpic.getAttribute("title") ? whichpic.getAttribute("title") : ""; var description = document.getElementById("description"); if(description.firstChild.nodeType == 3) { description.firstChild.nodeValue = text; } } //var gallery = document.getElementById("imagegallery"); //var links = gallery.getElementsByTagName("a"); //alert(links[0].onClick); //count(); return true; } function prepareGallery() { //if(!document.getElementById) return false; //if(!document.getElementsByTagName) return false; //if(!document.getElementById("imagegallery")) return false; var gallery = document.getElementById("imagegallery"); var links = gallery.getElementsByTagName("a"); for(var i = 0; i < links.length; i++) { links[i].onClick = function() { showPic(this); return showPic(this) ? false : true; //showPic(this); //return false; } } } function addLoadEvent(func) { var oldonload = window.onload; if(typeof window.onload != 'function') { window.onload = func; } else { window.onload = function() { oldonload(); func(); } } } //window.onload = count; //addLoadEvent(count); addLoadEvent(prepareGallery); ``` 感觉这个addLoadEvent函数无法运行,在页面中点击链接时会直接跳转到新的图片的页面,而不是在下面的placeholder里面显示,
JS一个有关addLoadEvent的小问题
``` <!DOCTYPE html > <html lang="en" > <head> <meta charset="utf-8" /> <title>这是啥?</title> <link rel="stylesheet" href="css/layout.css" media="screen" /> </head> <body> <h1>不知道啊</h1> <ul id="imagegallery"> <li> <a href="image/1.jpg" onclick="showPic(this); return false;" title="This is One">One</a> </li> <li> <a href="image/2.jpg" title="This is Two">Two</a> </li> <li> <a href="image/3.jpg" title="This is Three">Three</a> </li> <li> <a href="image/4.jpg" title="This is Four">Four</a> </li> </ul> <img id="placeholder" height="270" width="480" src="image/sb.jpg" alt="这到底是啥?"/> <p id="description">我也不知道啊</p> <script type="text/javascript" src="js/mdzz.js"></script> </body> </html> ``` ``` function showPic(whichpic) { if(!document.getElementById("placeholder")) return false; var source = whichpic.getAttribute("href"); var placeholder = document.getElementById("placeholder"); if(placeholder.nodeName != "IMG") return false; placeholder.setAttribute("src", source); if(document.getElementById("description")) { var text = whichpic.getAttribute("title") ? whichpic.getAttribute("title") : ""; var description = document.getElementById("description"); if(description.firstChild.nodeType == 3) { description.firstChild.nodeValue = text; } } //var gallery = document.getElementById("imagegallery"); //var links = gallery.getElementsByTagName("a"); //alert(links[0].onClick); //count(); return true; } function prepareGallery() { //if(!document.getElementById) return false; //if(!document.getElementsByTagName) return false; //if(!document.getElementById("imagegallery")) return false; var gallery = document.getElementById("imagegallery"); var links = gallery.getElementsByTagName("a"); for(var i = 0; i < links.length; i++) { links[i].onClick = function() { showPic(this); return showPic(this) ? false : true; //showPic(this); //return false; } } } function addLoadEvent(func) { var oldonload = window.onload; if(typeof window.onload != 'function') { window.onload = func; } else { window.onload = function() { oldonload(); func(); } } } //window.onload = count; //addLoadEvent(count); addLoadEvent(prepareGallery); ``` 感觉这个addLoadEvent函数无法运行,在页面中点击链接时会直接跳转到新的图片的页面,而不是在下面的placeholder里面显示,
关于javascript 中的addLoadEvent重复实现函数问题
最近学习javascript的时候看的Javascript DOM编程艺术,中间作者提到了addLoadEvent() 函数,用来在页面加载完成后调用函数。 但发现有个函数会调用两次,求解答。 html文件代码: ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <title>Hello</title> </head> <body> <script src="../script/addLoadEvent.js"></script> <script src="../script/new_file.js"></script> <script src="../script/new_file1.js"></script> </body> </html> ``` js代码: addLoadEvent.js ``` function addLoadEvent(func) { var oldonload = window.onload; if(typeof window.onload != 'function') { window.onload = func; } else { oldonload(); func(); } } ``` new_file.js代码: ``` function fun1() { alert("fun1"); } addLoadEvent(fun1); ``` new_file1.js代码: ``` function fun2() { alert("fun2"); } addLoadEvent(fun2); ``` 运行时,会出现两次fun1 一直不懂,求大神解答
关于图片页面跳转的问题
``` 初学JavaScript,在《JavaScript DOM编程艺术》书中有个实例代码如下: <!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> </head> <body> <header> <img src="images/logo.gif" alt="Jay Skript and the Domsters" /> <nav> <ul> <li><a href="index.html">Home</a></li> <li><a href="about.html">About</a></li> <li><a href="photos.html">Photos</a></li> <li><a href="live.html">Live</a></li> <li><a href="contact.html">Contact</a></li> </ul> </nav> </header> <article> <h1>Photos of the band</h1> <ul id="imagegallery"> <li> <a href="images/photos/concert.jpg" title="The crowd goes wils"> <img src="images/photos/thumbnail_concert.jpg" alt="the band in concert" /> </a> </li> <li> <a href="images/photos/bassist.jpg" title="An atmospheric moment"> <img src="images/photos/thumbnail_bassist.jpg" alt="the bassist" /> </a> </li> <li> <a href="images/photos/guitarist.jpg" title="Rocking out"> <img src="images/photos/thumbnail_guitarist.jpg" alt="the guitarist" /> </a> </li> <li> <a href="images/photos/crowd.jpg" title="Encore! Encore! "> <img src="images/photos/thumbnail_crowd.jpg" alt="the audience" /> </a> </li> </ul> </article> <script> function addLoadEvent(func) { var oldonload = window.onload; if (typeof window.onload != 'function') { window.onload = func; } else { window.onload = function() { oldonload(); func(); } } } function insertAfter(newElement,targetElement) { var parent = targetElement.parentNode; if (parent.lastChild == targetElement) { parent.appendChild(newElement); } else { parent.insertBefore(newElement,targetElement.nextSibling); } } function showPic(pic) { if (!document.getElementById("placeholder")) return false; var source = pic.getAttribute("href"); var placeholder = document.getElementById("placeholder"); if (placeholder.nodeName !="IMG") return false; placeholder.setAttribute("src",source); if (document.getElementById("description")) { var text = pic.getAttribute("title") ? pic.getAttribute("title") : ""; var description = document.getElementById("description"); if (description.firstChild.nodeType == 3) { description.firstChild.nodeValue = text; } } return true; } function prepareGallery() { if (!document.getElementsByTagName) return false; if (!document.getElementById) return false; if (!document.getElementById("imagegallery")) return false; var gallery = document.getElementById("imagegallery"); var links = gallery.getElementsByTagName("a"); for (var i=0; i<links.length; i++) { links[i].onclick = function() { return !showPic(this); } } } addLoadEvent(prepareGallery); function preparePlaceholder() { var placeholder = document.createElement("img"); placeholder.setAttribute("id", "placeholder"); placeholder.setAttribute("src", "image06/placeholder.gif"); placeholder.setAttribute("alt", "my image gallery"); var description = document.createElement("p"); description.setAttribute("id", "description"); var desctext = document.createTextNode("Choose an image."); description.appendChild(desctext); var gallery = document.getElementById("imagegallery"); insertAfter(placeholder, gallery); insertAfter(description, placeholder); } addLoadEvent(preparePlaceholder); </script> </body> </html> 单击缩略图,图片会在本页显示(不会跳转到另一页显示); 如果把showPic(pic)函数改写成如下: function showPic(pic) { if (!document.getElementById("placeholder")) return false; var source = pic.getAttribute("href"); var placeholder = document.getElementById("placeholder"); placeholder.setAttribute("src", source); if (!document.getElementById("description")) return false; if (pic.getAttribute("title")) { var text = pic.getAttribute("title"); } else { var text = ""; } var description = document.getElementById("description"); if (description.firstChild.nodeType == 3) { description.firstChild.nodeValue = text; } return false; } 单击图片缩略图,图片就会跳转到新的页面显示;实在找不出原因,请各位老师指教,非常感谢! ```
dom编程艺术中的一段代码为什么会报错。 大神帮我看一下为什么一直显示15行有错
![图片说明](https://img-ask.csdn.net/upload/201703/06/1488763890_985421.png) js 源码 ``` function addLoadEvent(func) { var oldOnLoad = window.onload; if (typeof oldOnLoad != 'function') { window.onload = func; } else { window.onload = function () { oldOnLoad(); func(); } } } function insertAfter(newElement,targetElement) { var parent = targetElement.parentNode; if (parent.lastChild == targetElement) { parent.appendChild(newElement) } else { parent.insertBefore(newElement, targetElement.nextSibling) } } function preparePlaceholder() { var placeHolder = document.createElement("img"); placeHolder.setAttribute("id","placeHolder"); placeHolder.setAttribute("src","images/placeholder.gif"); placeHolder.setAttribute("alt","My Image Gallery"); var despription = document.createElement("p"); despription.setAttribute("id","description"); var text = document.createTextNode("Choose an image"); despription.appendChild(text); var gallery = document.getElementById("imageGallery"); insertAfter(placeHolder,gallery); insertAfter(despription,placeHolder); } function prepareGallery() { var links = document.getElementsByTagName("a"); for (var i = 0;i < links.length;i++){ links[i].onclick = function () { showPic(this); return false; } } } function showPic(whichPic) { var source = whichPic.getAttribute("href"); var goal = document.getElementById("placeholder"); goal.setAttribute("src",source); var text = whichPic.getAttribute("title"); var description = document.getElementById("description"); description.firstChild.nodeValue = text; } addLoadEvent(prepareGallery); addLoadEvent(preparePlaceholder); ``` html源码 ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>gallery_practise</title> <script type = "text/javascript" src= "Scrips/showPic.js"></script> </head> <body> <h1>Snapshots</h1> <ul id="imagegallery"> <li> <a href="images/fireworks.jpg" title = " fireworks look beautiful">Fireworks</a> </li> <li> <a href="images/coffee.jpg " title = "coffee tastes delicious" >Coffee</a> </li> <li> <a href="images/rose.jpg " title = "rose i want to give my girlfriend" >Rose</a> </li> <li> <a href="images/bigben.jpg " title="bigben is a big clock" >Bigben</a> </li> </ul> </body> </html> ```
JavaScript DOM编程艺术问题
新手初学JavaScript,第十章moveElement实验是碰到一个error, moveMessage的第三行报Uncaught TypeError: Cannot read property 'style' of nullmoveElement,自己尝试了一下断点调试,发现第一次运行moveMessage函数不会报错,第二次递归调用的时候就会报这个错,新人求助,html代码传上来标签就看不到了,无奈只好发图 ![图片说明](https://img-ask.csdn.net/upload/201605/08/1462712342_87050.jpg) addLoadEvent.js: function addLoadEvent(func){ var oldonload = window.onload; if(typeof window.onload != 'function'){ window.onload = func; }else{ window.onload = function(){ oldonload(); func(); } } } moveElement.js: function moveElement(elementID,final_x,final_y,interval){ var elem = document.getElementById(elementID); var xpos = parseInt(elem.style.left); var ypos = parseInt(elem.style.top); if(xpos == final_x && ypos == final_y){ return true; } if(xpos < final_x){ xpos++; } if(ypos < final_y){ ypos++; } if(xpos > final_x){ xpos--; } if(ypos > final_y){ xpos--; } elem.style.left = xpos + "px"; elem.style.top = ypos + "px"; var repeat = "moveElement('" +elementID+ "'," +final_x+ "," +final_y+ "," +interval+ ")"; movement = setTimeout(repeat,interval); } addLoadEvent(moveElement); positionMessage.js: function positionMessage(){ var elem = document.getElementById("message"); elem.style.position = "absolute"; elem.style.left = "50px"; elem.style.top = "100px"; moveElement("message",200,100,10); } addLoadEvent(positionMessage);
javascript addLoadEvent函数为什么在页面加载后调用的函数没有执行
``` # 函数如下 function addLoadEvent(func){ var oldonload=window.onload; if(typeof window.onload !='function'){ window.onload=func; } else{ window.onload=function(){ oldonload(); func(); } } } ``` ``` ``` function loadEvents() { // home prepareSlideshow(); // about prepareInternalnav(); // photos preparePlaceholder(); prepareGallery(); // live stripeTables(); highlightRows(); displayAbbreviations(); // contact focusLabels(); prepareForms(); } ``` ``` // Load events addLoadEvent(highlightPage); addLoadEvent(loadEvents); ``` 函数我可以保证没写错,我是在看javasript DOM编程艺术这边书12章编写的时候出的问题,函数没有被执行,我试过火狐断点调试,并没有看出什么错误。。 ```
Javascript DOM编程艺术 Ajax XMLhttpRequest 实例问题
第二版 7章 P115页 AJAX中 XMLhttpRequest 的例子为何实现不了呢? ![![![图片说明](https://img-ask.csdn.net/upload/201705/18/1495090426_47813.png)图片说明](https://img-ask.csdn.net/upload/201705/18/1495090411_795048.png)图片说明](https://img-ask.csdn.net/upload/201705/18/1495090399_170604.png) ![图片说明](https://img-ask.csdn.net/upload/201705/18/1495090713_242087.png) 页面不能显示出example.txt 中的文本 会先弹出RequestReceived 在弹出 Function Done 页面上都是空白 试了几个浏览器都没打开 还有 DOM 7章 重返图片库P 112页 也没实现 这是HTML页面代码 ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8" /> <title>Image Gallery</title> <style> body { font-family: "Helvetica", "Arial", "serif"; color: #333; background-color: #ccc; margin: 1em 10%; } h1 { color: #333; background-color: transparent; } a { color: #c60; background-color: transparent; font-weight: bold; text-decoration: none; } ul { padding: 0; } li { float: left; padding: 1em; list-style: none; } img { display: block; clear: both; padding: 20px 20px; } #imagegallery { list-style: none; } #imagegallery li { display: inline; } #imagegallery li a img { border: 0; } </style> </head> <body> <h1>Snapshots</h1> <ul id="imagegallery"> <li> <a href="p1.jpg" title="A firework display"><img src="p1.jpg" alt="Firework" width="150" height="120"></a> </li> <li> <a href="p2.jpg" title="A cup of black coffee"><img src="p2.jpg" alt="Coffee" width="150" height="120"></a> </li> <li> <a href="p3.jpg" title="A red, red rose"><img src="p3.jpg" alt="Rose" width="150" height="120"></a> </li> <li> <a href="p4.jpg" title="The famous clock"><img src="p4.jpg" alt="BigBen" width="150" height="120"></a> </li> </ul> <script src="fun.js"></script> </body> </html> JS中的代码 function addLoadEvent(func) { var oldonload = window.onload; if (typeof window.onload != 'function') { window.onload = func; } else { window.onload = function() { oldonload(); func(); } } } function insertAfter() { var parent = targetElement.parentNode; if (parent.lastChild == targetElement) { parent.appendChild(newElement); } else { parent.insertBefore(newElement, targetElement.nextSibling); } } function preparePlaceholder() { if (!document.createElement) return false; if (!document.createTextNodde) return false; if (!document.getElementById) return false; if (!document.getElementById("imagegallery")) return false; var placeholder = document.createElement("img"); placeholder.setAttribute("id", "palceholder"); placeholder.setAttribute("src", "p5.jpg"); placeholder.setAttribute("alt", "my image gallery"); var description = document.createElement("p"); description.setAttribute("id", "description"); var desctext = document.createTextNode("choose an image"); description.appendChild(desctext); var gallery = document.getElementById("imagegallery"); insertAfter(placeholder, gallery); insertAfter(description, placeholder); } function prepareGallery() { if (!document.getElementsByTagName) return false; if (!document.getElementById) return false; if (!document.getElementById("imagegallery")) return false; var gallery = document.getElementById("imagegallery"); var links = gallery.getElementsByTagName("a"); for (var i = 0; i < links.length; i++) { links[i].onclick = function() { return !showPic(this); } links[i].onkeypresss = links[i].onclick; } } function showPic(whichpic) { if (!document.getElementById("placeholder")) return true; var source = whichpic.getAttribute("href"); var placeholder = document.getElementById("placeholder"); placeholder.setAttribute("src", source); if (placeholder.nodeName != "IMG") return false; if (document.getElementById("description")) { var text = whichpic.getAttribute("title") ? whichpic.getAttribute("title") : ""; var description = document.getElementById("description"); if (description.firstChild.nodeType == 3) { description.firstChild.nodeValue = text; } } return false; } addLoadEvent(preparePlaceholder); addLoadEvent(prepareGallery); ``` ![图片说明](https://img-ask.csdn.net/upload/201705/18/1495090989_349453.png) 这是页面显示出来的效果 图片点击后没反应,之前改了几次都没成功。 新手还在学习中,见谅
简单的javascript动画的运行问题
# 写了一段很简单的动画代码,调试时有问题,自己找了半天也不知道哪边错了 ## 下面是html代码 ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>moveMessage</title> <script type="text/javascript" src="js/move.js"></script> <script type="text/javascript" src="js/addLoadEvent.js"></script> </head> <body> <p id="message"> Yummy!!! </p> <p id="message2">Whee!!!</p> </body> </html> ``` ## js代码 ``` function moveElemnet(elementID,final_x,final_y,interval){ console.log(); console.trace(); if(!document.getElementById) return false; if(!document.getElementById(elementID)) return false; var elem = document.getElementById(elementID); var xpos = parseInt(elem.style.left); var ypos = parseInt(elem.style.top); if(xpos == final_x && ypos == final_y){ return true; } if(xpos < final_x){ xpos++; } if(xpos > final_x){ xpos--; } if(ypos < final_y){ ypos++; } if(ypos > final_y){ ypos--; } elem.style.left = xpos + "px"; elem.style.top = ypos + "px"; var repeat = "moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")"; alert(repeat); movement = setTimeout(repeat,interval); } function positionMessage(){ console.log(); console.trace(); if(!document.getElementById) return false; if(!document.getElementById("message")) return false; var elem = document.getElementById("message"); elem.style.position = "absolute"; elem.style.left = "200px"; elem.style.top = "400px"; moveElemnet("message",400,800,10); if(!document.getElementById("message2")) return false; var elem = document.getElementById("message2"); elem.style.position = "absolute"; elem.style.top = "50px"; elem.style.left = "50px"; moveElemnet("message2",125,25,20); } ``` ``` function addLoadEvent(func){ var oldonload = window.onload; if(typeof window.onload != 'function'){ window.onload = func; }else{ window.onload = function(){ oldonload() func(); } } } addLoadEvent(positionMessage); addLoadEvent(moveElemnet); ``` ## 调试截图 ![图片说明](https://img-ask.csdn.net/upload/201612/26/1482742130_213898.png) ![图片说明](https://img-ask.csdn.net/upload/201612/26/1482742143_297486.png) ![图片说明](https://img-ask.csdn.net/upload/201612/26/1482742154_436971.png) 望大神解答
JAVA爬虫 爬取 https://www.zhipin.com/?ka=header-home 出现问题
JAVA爬虫 爬取 https://www.zhipin.com/?ka=header-home 出现问题 ,自己使用了ip代理 ``` public static Elements getJsoupDocGet(String url) throws IOException { Document doc = null; Random random = new Random(); int i = 0; while (i < 10 && doc == null) { try { trustEveryone(); IpProxy ipProxy = getRandomIP(); System.out.println(ipProxy.getIp()+" "+ipProxy.getPort()); System.setProperty("http.maxRedirects", "50"); System.getProperties().setProperty("proxySet", "true"); System.getProperties().setProperty("http.proxyHost", ipProxy.getIp()); System.getProperties().setProperty("http.proxyPort", ipProxy.getPort()); doc = Jsoup.connect(url) .userAgent(getUserAgent(ua)) .header("Accept-Encoding", "gzip, deflate,br") .header("Accept-Language", "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3") .header("User-Agent", "Mozilla/31.0 (compatible; MSIE 10.0; Windows NT; DigExt)") .header("Content-Type", "application/x-www-form-urlencoded") .header("Cache-Control","no-cache" ) .header("Pragma", "no-cache") .header("Upgrade-Insecure-Requests", "1") .header("Connection", "Keep-alive") .header("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8") .ignoreContentType(true) .ignoreHttpErrors(true) .timeout(1000 * 60) .cookie("auth", "token") .post(); if (doc != null) { System.out.println("代理成功"); //System.out.println(doc.toString()); return doc.select("body"); } } catch (Exception e) { } i++; } if (doc == null) { doc = Jsoup.connect(url).header("Accept", "*/*").header("Accept-Encoding", "gzip, deflate") .header("Accept-Encoding", "gzip, deflate") .header("Accept-Language", "zh-CN,zh;q=0.8,en-US;q=0.5,en;q=0.3") .header("User-Agent", "Mozilla/31.0 (compatible; MSIE 10.0; Windows NT; DigExt)") .header("Content-Type", "application/x-www-form-urlencoded") .header("Cache-Control","no-cache" ) .header("Pragma", "no-cache") .header("Upgrade-Insecure-Requests", "1") .header("Connection", "Keep-alive") .header("Accept", "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8") .timeout(1000 * 60) .userAgent(getUserAgent(ua)) .cookie("auth", "token") .post(); } return doc.select("body"); } ``` 爬取网站时出现了下面的问题 但是有浏览器可以正常看,且代码也是完整的 ``` 代理成功 <body> <div style="font-size: 12px;"> 请稍后... </div> <input type="hidden" id="page_key_name" value="security_bridge"> <script> var _T=_T||[];!function(){var b,a=document.createElement("script");a.src="https://static.zhipin.com/library/js/analytics/ka.js",b=document.getElementsByTagName("script")[0],b.parentNode.insertBefore(a,b)}(),function(){var e,f,g,h,a=function(a,b){var c,d,e,f;"object"!=typeof a&&(a=[a]),c=document.getElementsByTagName("head").item(0)||document.documentElement,d=new Array,e=a.length-1,f=function(g){d[g]=document.createElement("script"),d[g].setAttribute("type","text/javascript"),d[g].setAttribute("charset","UTF-8"),d[g].onload=d[g].onreadystatechange=function(){this.onload=this.onreadystatechange=null,this.parentNode.removeChild(this),g!=e?f(g+1):"function"==typeof b&&b()},d[g].setAttribute("src",a[g]),c.appendChild(d[g])},f(0)},b=function(a){var b=new RegExp("(^|&)"+a+"=([^&]*)(&|$)"),c=window.location.search.substr(1).match(b);return null!=c?unescape(c[2]):null},c={get:function(a){var b,c=new RegExp("(^| )"+a+"=([^;]*)(;|$)");return(b=document.cookie.match(c))?unescape(b[2]):null},set:function(a,b,c,d,e){var g,f=a+"="+encodeURIComponent(b);c&&(g=new Date(c).toGMTString(),f+=";expires="+g),f=d?f+";domain="+d:f,f=e?f+";path="+e:f,document.cookie=f}};window.location.href,e=decodeURIComponent(b("seed"))||"",f=b("ts"),g=b("name"),h=decodeURIComponent(b("callbackUrl")),e&&f&&g&&a("security-js/"+g+".js",function(){var a=(new Date).getTime()+2304e5,b=".zhipin.com",d=(new ABC).z(e,parseInt(f));window.location.host.indexOf(".weizhipin.com")>-1&&(b=".weizhipin.com"),c.set("__zp_stoken__",d,a,b,"/");try{_T.sendEvent("security_bridge_"+d)}catch(g){}h?window.location.href=h:window.history.back()})}(); </script> </body> ``` 求大佬给出解答方式,求救救,自己在网上搜的设置ip代理代码,应该没错,别的网页可以,只有自己爬取的网页有问题
DOM对象操作为什么只能对一个页面有效果,其他页面不行?
我建了两个页面,分别命名为index.html(主页)和about.html.然后将javascript代码命名为 global.js,里面同时包含操控这两个页面的函数。将global.js同时插入到两个页面的body标签最后。 结果是作用于index.html页面的函数一切工作正常,但作用于about.html页面的函数却不起作用。求解释。 index.html ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>TEST</title> <script src="scripts/modernizr.js"></script> <link rel="stylesheet" media="screen" href="styles/index.css" /> </head> <body> <header> <div id="logos"> <img id="logo" src="images/logo.jpg" alt="SIEA" /> <a href="http://www.zju.edu.cn/" class="linklogo"><img src="images/school.gif" alt="浙江大学" /></a> <a href="http://oc.zju.edu.cn/" class="linklogo"><img src="images/collage.gif" alt="海洋学院" /></a> </div> <nav> <ul> <li><a href="index.html">Home</a></li> <li><a href="about.html">About</a></li> <li><a href="photos.html">Photos</a></li> <li><a href="live.html">Live</a></li> <li><a href="contact.html">Contact</a></li> <li><a href="arrangement.html">Arrangement</a></li> </ul> </nav> </header> <article> <h1>Welcome</h1> <p> <span>T</span>oday,we are going to introduce some kinds of fruits. The first type of fruit is the <a href="#" title="apple">Apple</a>.The second type of fruit is the <a href="#" title="banana"> Banana</a>.The last type of fruit is the <a href="#" title="cherry">Cherry</a>.We all love eating fruits. Let us have a look!!! </p> <div id="slideshow"> <img src="images/fruits.jpg" alt="fruits" id="preview" /> </div> </article> <footer> <p>Designed by <abbr title="Zhejiang University">ZJU</abbr> Mareine Geology Lab</p> </footer> <script src="scripts/global.js"></script> </body> </html> ``` about.html ``` <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title>TEST</title> <script src="scripts/modernizr.js"></script> <link rel="stylesheet" media="screen" href="styles/about.css" /> </head> <body> <header> <div id="logos"> <img id="logo" src="images/logo.jpg" alt="SIEA" /> <a href="http://www.zju.edu.cn/" class="linklogo"><img src="images/school.gif" alt="浙江大学" /></a> <a href="http://oc.zju.edu.cn/" class="linklogo"><img src="images/collage.gif" alt="海洋学院" /></a> </div> <nav> <ul> <li><a href="index.html">Home</a></li> <li><a href="about.html">About</a></li> <li><a href="photos.html">Photos</a></li> <li><a href="live.html">Live</a></li> <li><a href="contact.html">Contact</a></li> <li><a href="arrangement.html">Arrangement</a></li> </ul> </nav> </header> <article> <h1>About the band</h1> <nav> <ul> <li><a href="#jay">Jay Skript</a></li> <li><a href="#domsters">The Domsters</a></li> </ul> </nav> <section id="jay"> <h2>Jay Skript</h2> <p>Jay Skript is going to rock your world!</p> <p>Together with his compatriots the Domsters, Jay is set for world domination. Just you wait and see. </p> <p>Jay Skript has been on the scene since the mid 1990s. His talent has not always been recognized or fully appreciated. In the early days, he was ofen unfavorably compared to bigger, similarly named artists. That is all in the past now.</p> </section> <section id="domsters"> <h2>The Domsters</h2> <p>The Domsters have been around, in one form or another, for almost as long. it is only in the past few years that the Domsters have settled down to their current, stable lineup. Now they're a rock-solid bunch: methodical and dependable.</p> </section> </article> <footer> <p>Designed by <abbr title="Zhejiang University">ZJU</abbr> Mareine Geology Lab</p> </footer> <script src="scripts/global.js"></script> </body> </html> ``` global.js ``` function addLoadEvent(func) //将函数添加到window.onload事件中 { var oldonload=window.onload; if (typeof window.onload!='function') { window.onload=func; }else { window.onload= function(){ oldonload(); func(); } } } function insertAfter(newElement,targetElement) //在元素后面插入元素 { var parent=targetElement.parentNode; if (parent.lastChild==targetElement) { parent.appendChild(newElement); }else { parent.insertBefore(newElement,targetElement.nextSibling); } } function addclass(element,value) //为元素加类 { if (!element.className) { element.className=value; }else { newClassName=element.className; newClassName+=' '; newClassName+=value; element.className=newClassName; } } function highlightPage() //作用于所有页面,使当前页面的导航按钮高亮 { if (!document.getElementsByTagName) return false; var headers=document.getElementsByTagName('header'); if (headers.length==0) return false; var navs=headers[0].getElementsByTagName('nav'); if (navs.length==0) return false; var links=navs[0].getElementsByTagName('a'); if (links.length==0) return false; for (var i=0;i<links.length;i++) { linkurl=links[i].getAttribute("href"); if (window.location.href.indexOf(linkurl)!=-1) { links[i].className="here"; } } } function moveElement(elementID,final_x,final_y,interval) //作用于index页面,使元素移动 { if (!document.getElementById) return false; var elem=document.getElementById(elementID); if (!elem) return false; if (elem.movement) clearTimeout(elem.movement) var xpos=parseInt(elem.style.left); var ypos=parseInt(elem.style.top); if (xpos==final_x && ypos==final_y) return true; if (xpos<final_x) xpos++; if (xpos>final_x) xpos--; if (ypos<final_y) ypos++; if (ypos>final_y) ypos--; elem.style.top=ypos+'px'; elem.style.left=xpos+'px'; var repeat="moveElement('"+elementID+"',"+final_x+","+final_y+","+interval+")"; elem.movement=setTimeout(repeat,interval); } function prepareSlideshow() //作用于index页面,使元素的移动与鼠标事件挂钩(冲突函数) { if (!document.getElementsByTagName) return false; if (!document.getElementById) return false; var preview=document.getElementById('preview'); preview.style.position="absolute"; preview.style.top="0px"; preview.style.left="0px"; var articles=document.getElementsByTagName('article'); if (articles.length==0) return false; var ps=articles[0].getElementsByTagName('p'); if (ps.length==0) return false; var links=ps[0].getElementsByTagName('a'); if (links.length==0) return false; links[0].onmouseover=function(){ moveElement("preview",0,0,10); } links[1].onmouseover=function(){ moveElement("preview",-325,0,10); } links[2].onmouseover=function(){ moveElement("preview",-640,0,10); } } function showSection(id) //作用于about页面,使当前章节显示 { if (!document.getElementById) return false; if (!document.getElementsByTagName) return false; var articles=document.getElementsByTagName('article'); if (articles.length==0) return false; var sections=articles[0].getElementsByTagName('section'); if (sections.length==0) return false; for (var i=0;i<sections.length;i++) { if (sections[i].getAttribute('id')==id) sections[i].style.display='block'; else sections[i].style.display='none'; } } function prepareInternalnav() //作用于about页面,使显示函数与鼠标点击事件挂钩(冲突函数) { if (!document.getElementsByTagName) return false; var articles=document.getElementsByTagName('article'); if (articles.length==0) return false; var navs=articles[0].getElementsByTagName('nav'); if (navs.length==0) return false; var links=navs[0].getElementsByTagName('a'); if (links.length!=2) return false; links[0].destination=links[0].getAttribute('href').split('#')[1]; links[1].destination=links[1].getAttribute('href').split('#')[1]; document.getElementById(links[0].destination).style.display='none'; document.getElementById(links[1].destination).style.display='none'; links[0].onclick=function(){ showSection(links[0].destination); return false; } links[1].onclick=function(){ showSection(links[1].destination); return false; } } addLoadEvent(highlightPage); //addLoadEvent(prepareSlideshow); //将一个index页面的函数屏蔽,则about页面函数运行正常 addLoadEvent(prepareInternalnav); ```
将jsp页面上的信息传递到action中
各位大神,求帮忙!!! 页面上的信息是这样: <body onload="init();"> <table class="tabmenu" <c:if test="${fn:length(tabmap) < 2}">style="display:none"</c:if>> <tr> <c:forEach var="tab" items="${tabmap}" varStatus="vs"> <td class="tabitem"> <a id="${vs.index}" onclick="return clickTab(${vs.index}, this.href);" href="<c:url value='/${tab.value}'/>" class="menulink" target="main"><fmt:message key="${tab.key}"/></a> </td> <c:choose> <c:when test="${fn:length(tabmap)==vs.index+1}"> <td class="sep3" id="_${vs.index}"></td> </c:when> <c:otherwise> <td class="sep2" id="_${vs.index}"></td> </c:otherwise> </c:choose> </c:forEach> </tr> </table> </body> 想要获取其中的 id="${vs.index}"的href,让action获取 并存在库表中。 页面的js如下: function clickTab(tabId, href) { try{ caCanvas.show(); var total = ${fn:length(tabmap)}; var selectedTab = document.getElementById(tabId).parentNode; var selectedTab_ = document.getElementById("_" + tabId); var _selectedTab = document.getElementById("_" + (tabId - 1)); for(var i = 0; i < total; i++) { var tab = document.getElementById(i).parentNode; var tab_ = document.getElementById("_" + i); tab.className = "tabitem"; if(total == i + 1) { tab_.className = "sep3"; } else { tab_.className = "sep2"; } } selectedTab.className = "selected"; if(total == parseInt(tabId) + 1) { selectedTab_.className = "sep5"; } else { selectedTab_.className = "sep1"; } if(_selectedTab) { _selectedTab.className = "sep4"; } if(href && href.indexOf('engineTab=1') != -1){ if(typeof(eval(window.parent.frames["head"].window.displayEngineTab)) == "function"){ window.parent.frames["head"].window.displayEngineTab(""); } }else{ if(typeof(eval(window.parent.frames["head"].window.displayEngineTab)) == "function"){ window.parent.frames["head"].window.displayEngineTab("none"); } } var expires = getExpDate(30, 0, 0); var id = "<c:out value='${id}' default='' />" addMainCookie(nameSpace + "tabmenu", id + "<"+tabId); dealEngineIcon(href); return true; }catch(e){} } 上面function中的href就是我所需要传递的值,我查看网上有说是用AJAX的还有使用隐藏域的还有使用session的 可是我都用了不好使,也许是我写错了 ,求各位大神看看能不能帮帮小弟,怎么写出来,思路是什么样的?谢谢谢谢谢
下面是一个html和js实现的wheel移动到目的位置,但是浏览器报错,错误应该在指定行,
``` <!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="Generator" content="EditPlus®"> <meta name="Author" content=""> <meta name="Keywords" content=""> <meta name="Description" content=""> <title></title> </head> <body> <p id='message'>Wheel!</p> </body> <script> /* 该函数用于同时加载多个函数, 以避免连用window.onload情况的发生 (因为如果连用window.onload,那么后面 的将会覆盖前面的); */ function addEventLoad(func){ var oldonload=window.onload; if(typeof window.onload!='function'){ window.onload=func; }else{ window.onload=function(){ oldonload(); func(); }; } } function moveElement(elementID,final_x,final_y,interval){ alert(elementID); if(!document.getElementById) return false; if(!document.getElementById(elementID)) return false; var elem=document.getElementById(elementID); var xpos=parseInt(elem.style.left); var ypos=parseInt(elem.style.top); if(xpos==final_x&&ypos==final_y) return true; if(xpos<final_x){ xpos++; }else{ xpos--; } if(ypos<final_y){ ypos++; }else{ ypos--; } elem.style.left=xpos+'px'; elem.style.top=ypos+'px'; //**下一行报错** var repeat= "moveElement("+elementID+","+final_x+","+final_y+","+interval")"; movement=setTimeout(repeat,interval); } function positionMessage(){ if(!document.getElementById) return false; if(!document.getElementById('message')) return false; var elem=document.getElementById('message'); elem.style.position='absolute'; elem.style.left='50px'; elem.style.top='100px'; moveElement('message',200,100,10); } addEventLoad(positionMessage); </script> </html> ```
js中cssText可以用变量赋值吗
``` <script type="text/javascript"> window.onload = function(){ var attrInt = document.getElementsByTagName('input')[0].value; var attrNum = document.getElementsByTagName('input')[1].value; var enterBtn = document.getElementsByTagName('button')[0]; var resetBtn = document.getElementsByTagName('button')[1]; var changeBox = document.getElementById('willBox'); enterBtn.onclick = function(){ changeBox.style.cssText = '"attrInt":"attrNum";' ; } resetBtn.onclick = function(){ changeBox.style.cssText = ""; } console.log(typeof attrInt); console.log(attrInt); console.log(typeof attrNum); console.log(attrNum); } </script> ``` 运行之后实现不了用户输入值,改变div属性的想法。 代码中“ changeBox.style.cssText = '"attrInt":"attrNum"这一段还望解惑,谢谢!
获取的图片地址乱码解决,但是保存的图片乱码怎么解决?在线等,求大神,解决,速结贴
package com.togest.emis.modules.resource.web; import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.net.URLDecoder; import java.util.Map; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.codec.binary.Base64; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import com.togest.emis.framework.utils.EncodeUtils; /** * * * @author mmk * */ @Controller public class PsaveController { @RequestMapping(value="save",method = RequestMethod.POST) public void save(Map<String,Object> map,HttpServletRequest request,HttpServletResponse response) throws IOException{ String imageData2 = request.getParameter("imageData2"); String file_path = request.getParameter("file_path"); file_path = URLDecoder.decode(file_path , "utf-8"); System.out.println("++++++++++++++++"+file_path); //String f = new String(request.getParameter("file_path").getBytes("ISO-8859-1"),"UTF-8"); //System.out.println("+++++++++++++++++"+f); String file_name = request.getParameter("file_name"); String Path = request.getSession().getServletContext().getRealPath("/"); String filePath2 = file_path.substring(0, 34); String filePath=file_path.replace(filePath2,Path); filePath =EncodeUtils.isoDecode(filePath); String fileName=file_name; File file = new File(filePath); System.out.println("+++++++"+filePath); //System.out.println("+++++++++"+EncodeUtils.isoDecode(filePath)); if(imageData2!=null){ try{ FileOutputStream write = new FileOutputStream(file); byte[] decoderBytes = Base64.decodeBase64(imageData2.replace("data:image/png;base64,","")); imageData2 = imageData2.replace("base64,",""); write.write(decoderBytes); write.flush(); write.close(); }catch(Exception e){ e.printStackTrace(); } } } } 保存控制器代码 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ include file="/common/taglibs.jsp"%> <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <title></title> <!-- jQuery --> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery-1.8.2.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery.ui.core.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery.ui.widget.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery.ui.mouse.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery.ui.draggable.min.js"></script> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/jquery.base64.js"></script> <!-- wColorPicker --> <link rel="Stylesheet" type="text/css" href="${pageContext.request.contextPath}/system/css/wColorPicker.css" /> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/wColorPicker.js"></script> <!-- wPaint --> <link rel="Stylesheet" type="text/css" href="${pageContext.request.contextPath}/system/css/wPaint.css" /> <script type="text/javascript" src="${pageContext.request.contextPath}/system/js/wPaint.js"></script> </head> <body> <!-- <img id="canvasImage3" onload="DrawImage(this)" style="display:none" src="${requestScope.filePath}" name="${requestScope.fileName}" />--> <img id="canvasImage3" onload="DrawImage(this)" style="display:none" /> <table id="full"> <tr> <td> <div id="wPaint2" style="position:relative; width:1620px;height:1200px;background:#CACACA; border:solid black 1px;"> </div> </td> <!-- <td><img id="canvasImage2" src=""/></td>--> </tr> <tr> <td colspan="2"> <div> <div id="box"></div> <input type="button" value="保存" onClick="saveImage2()" onblur="saveImage2()" /> <input type="button" value="提交" onblur="saveImage2()" onclick="saveImage2()"> <input type="button" value="全屏" onclick="full_screen()"> </div> <br /> </td> </tr> </table> <br /> <br /> <script type="text/javascript"> $(document).ready(function() { //alert('${filePath}'); ///alert('${ctx}/fileupload/download_file_url?fileDir=${filePath}'); $('#canvasImage3').attr('src','${ctx}/fileupload/download_file_url?fileDir=${filePath}'); }); function saveImage2() { var imageData2 = $("#wPaint2").wPaint("image");//获取wPaint的image属性值可获取base64格式的图片数据 var file_path = encodeURI(document.getElementById("canvasImage3").src);//这个获取乱码 file_path = encodeURI(file_path); var file_name = document.getElementById("canvasImage3").name; alert(file_path); $.ajax({ url : '${ctx}/save', type : 'post', data : { imageData2 : imageData2, file_path : file_path, file_name : file_name }, dataType : "json", success : function(result) { alert(result); if ("ture" == $.trim(result)) { $("#box").html("保存成功"); } else { $("#box").html("保存失败"); } }, error : function() { $("#box").html("保存成功"); } }); //$("#canvasImage2").attr('src', imageData2); } function convertCanvasToImage(canvas) { var image = new Image(); image.src = canvas.toDataURL("image/png"); return image; } var flag = false; //控制小图 function DrawImage(ImgD) { var image = new Image(); image.src = ImgD.src; if (image.width > 1620 || image.height > 1200) { image.width = 1620; image.height = 1200; } $("#wPaint2").css({ width : image.width, height : image.height }); $("#wPaint2").wPaint({ menuOrientation : 'vertical', imageBg : image.src }); } function full_screen() { var full = document.getElementById("full"); requestFullScreen(full); } function requestFullScreen(element) { var requestMethod = element.requestFullScreen || element.webkitRequestFullScreen || element.mozRequestFullScreen || element.msRequestFullScreen; if (requestMethod) { requestMethod.call(element); } else if (typeof window.ActiveXObject !== "undefined") { var wscript = new ActiveXObject("WScript.Shell"); if (wscript !== null) { wscript.SendKeys("{F11}"); } } } </script> </body> </html> 编辑页面如下
js代码用的好好的突然报错了,求大神指教
报错信息: Uncaught TypeError: this.onStart is not a function at Object.Start (focus.js:83) at window.onload (focus.js:124) js原码:// JavaScript Document //计算idslider2的宽度开始 var kuan1=0; var kuand=document.getElementById('idSlider2') var kuan=document.getElementById('idSlider2').getElementsByTagName("li"); var tpz=kuan.length;//图片总个数 for(var i=0; i<kuan.length; i++){ kuan1+=400; } kuand.style.width=kuan1+'px'; //计算结束 var keVar = function (id) { return "string" == typeof id ? document.getElementById(id) : id; }; var Class = { create: function() { return function() { this.initialize.apply(this, arguments); } } } Object.extend = function(destination, source) { for (var property in source) { destination[property] = source[property]; } return destination; } var TransformView = Class.create(); TransformView.prototype = { //容器对象,滑动对象,切换参数,切换数量 initialize: function(container, slider, parameter, count, options) { if(parameter <= 0 || count <= 0) return; var oContainer = keVar(container), oSlider = keVar(slider), oThis = this; this.Index = 0;//当前索引 this._timer = null;//定时器 this._slider = oSlider;//滑动对象 this._parameter = parameter;//切换参数 this._count = count || 0;//切换数量 this._target = 0;//目标参数 this.SetOptions(options); this.Up = !!this.options.Up; this.Step = Math.abs(this.options.Step); this.Time = Math.abs(this.options.Time); this.Auto = !!this.options.Auto; this.Pause = Math.abs(this.options.Pause); this.onStart = this.options.onStart; this.onFinish = this.options.onFinish; oContainer.style.overflow = "hidden"; oContainer.style.position = "relative"; oSlider.style.position = "absolute"; oSlider.style.top = oSlider.style.left = 0; }, //设置默认属性 SetOptions: function(options) { this.options = {//默认值 Up: true,//是否向上(否则向左) Step: 5,//滑动变化率 Time: 10,//滑动延时 Auto: true,//是否自动转换 Pause: 3000,//停顿时间(Auto为true时有效) onStart: function(){},//开始转换时执行 onFinish: function(){}//完成转换时执行 }; Object.extend(this.options, options || {}); }, //开始切换设置 Start: function() { if(this.Index < 0){ this.Index = this._count - 1; } else if (this.Index >= this._count){ this.Index = 0; } this._target = -1 * this._parameter * this.Index; this.onStart(); this.Move(); }, //移动 Move: function() { clearTimeout(this._timer); var oThis = this, style = this.Up ? "top" : "left", iNow = parseInt(this._slider.style[style]) || 0, iStep = this.GetStep(this._target, iNow); if (iStep != 0) { this._slider.style[style] = (iNow + iStep) + "px"; this._timer = setTimeout(function(){ oThis.Move(); }, this.Time); } else { this._slider.style[style] = this._target + "px"; this.onFinish(); if (this.Auto) { this._timer = setTimeout(function(){ oThis.Index++; oThis.Start(); }, this.Pause); } } }, //获取步长 GetStep: function(iTarget, iNow) { var iStep = (iTarget - iNow) / this.Step; if (iStep == 0) return 0; if (Math.abs(iStep) < 1) return (iStep > 0 ? 1 : -1); return iStep; }, //停止 Stop: function(iTarget, iNow) { clearTimeout(this._timer); this._slider.style[this.Up ? "top" : "left"] = this._target + "px"; } }; window.onload=function(){ function Each(list, fun){ for (var i = 0, len = list.length; i < len; i++) { fun(list[i], i); } }; var objs2 = keVar("idNum2").getElementsByTagName("li"); var tv2 = new TransformView("idTransformView2", "idSlider2", 400, tpz, { onStart: function(){ Each(objs2, function(o, i){ o.className = tv2.Index == i ? "on" : ""; }) },//按钮样式 Up: false });//6是轮播总数 tv2.Start(); Each(objs2, function(o, i){ o.onmouseover = function(){ o.className = "on"; tv2.Auto = false; tv2.Index = i; tv2.Start(); } o.onmouseout = function(){ o.className = ""; tv2.Auto = true; tv2.Start(); } }) }
在插入一个新用户的时候一直显示网络错误
![图片说明](https://img-ask.csdn.net/upload/201906/21/1561105721_387160.png)这一段出错,是这个文件有问题吗![图片说明](https://img-ask.csdn.net/upload/201906/21/1561105870_774201.png) if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Ut[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),k.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),k.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return k.globalEval(e),e}}}),k.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),k.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=k("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Vt,Gt=[],Yt=/(=)\?(?=&|$)|\?\?/;k.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Gt.pop()||k.expando+"_"+kt++;return this[e]=!0,e}}),k.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Yt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Yt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Yt,"$1"+r):!1!==e.jsonp&&(e.url+=(St.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||k.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?k(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Gt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Vt=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Vt.childNodes.length),k.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=D.exec(e))?[t.createElement(i[1])]:(i=we([e],t,o),o&&o.length&&k(o).remove(),k.merge([],i.childNodes)));var r,i,o},k.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=mt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&k.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?k("<div>").append(k.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},k.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){k.fn[t]=function(e){return this.on(t,e)}}),k.expr.pseudos.animated=function(t){return k.grep(k.timers,function(e){return t===e.elem}).length},k.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=k.css(e,"position"),c=k(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=k.css(e,"top"),u=k.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,k.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},k.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){k.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===k.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===k.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=k(e).offset()).top+=k.css(e,"borderTopWidth",!0),i.left+=k.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-k.css(r,"marginTop",!0),left:t.left-i.left-k.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===k.css(e,"position"))e=e.offsetParent;return e||ie})}}),k.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;k.fn[t]=function(e){return _(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),k.each(["top","left"],function(e,n){k.cssHooks[n]=ze(y.pixelPosition,function(e,t){if(t)return t=_e(e,n),$e.test(t)?k(e).position()[n]+"px":t})}),k.each({Height:"height",Width:"width"},function(a,s){k.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){k.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return _(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?k.css(e,t,i):k.style(e,t,n,i)},s,n?e:void 0,n)}})}),k.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){k.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}}),k.fn.extend({hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),k.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)}}),k.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||k.guid++,i},k.holdReady=function(e){e?k.readyWait++:k.ready(!0)},k.isArray=Array.isArray,k.parseJSON=JSON.parse,k.nodeName=N,k.isFunction=m,k.isWindow=x,k.camelCase=V,k.type=w,k.now=Date.now,k.isNumeric=function(e){var t=k.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},"function"==typeof define&&define.amd&&define("jquery",[],function(){return k});var Qt=C.jQuery,Jt=C.$;return k.noConflict=function(e){return C.$===k&&(C.$=Jt),e&&C.jQuery===k&&(C.jQuery=Qt),k},e||(C.jQuery=C.$=k),k}); $.ajax({ type: "post", url: getPath() + "/registerUser", async: false, dataType:'json', contentType: 'application/json', data:JSON.stringify({"id":0,"name":userName,"password":userPassword,"email":userEmail,"role":false}), success: function (data) { if (data.flag) { $('#userName').addClass('is-valid'); $('#userPassword').addClass('is-valid'); $('#userEmail').addClass('is-valid'); $('#userPasswordCheck').addClass('is-valid'); $('#registerResult').addClass('alert alert-success'); $('#registerResult').html('注册成功!跳转至<a href="login.html">登录</a>界面') setTimeout(window.location.href = 'login.html', 5000); } else { alert('注册失败'); } }, error: function () { alert("网络错误"); } }) }
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
程序员,职场上请远离这种人!
对有些职场人来讲,甩锅就是一种生存手段。01.从大学打篮球说起上大学的时候喜欢打篮球,然后我又特别喜欢抢篮板,经常是跳起来的时候没事,落下来的时候偶尔会踩到别人的脚上,于...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
一个读研让我损失了一百万的真实故事
关注我!只要10分钟,包你学会数据分析 毕业后,应该就业还是考研? 我刚出国留学那会儿,就惊讶的发现,外国local95%都不会选择读研 他们说,硕士学费很贵,时间宝贵,老板不认,所以很费 当几乎所有人都是本科学历时,硕士学历反而像个异类 在老板眼里,三年硕士远远不如3年的工作经验实用 他们甚至专门为拒绝高学历者发明了一个词,叫overoccupie...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
杭漂程序员2019的心路历程,还不起助学贷款,交不起房租,披荆斩棘终雨过天晴
一个杭漂2019的心酸历程,一路披荆斩棘终于还是雨过天晴。
我采访了同事,让他掏出了每天都会浏览的干货网站
前言只有光头才能变强。文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y在周六的晚上,我日常去到公司写文章。想写...
相关热词 c# id读写器 c#俄罗斯方块源码 c# linq原理 c# 装箱有什么用 c#集合 复制 c# 一个字符串分组 c++和c#哪个就业率高 c# 批量动态创建控件 c# 模块和程序集的区别 c# gmap 截图
立即提问