怎么把Ajax获取到的值赋值给js变量?

就是想发送个post请求,并把数据赋值给其他变量,我这么从后台获取到数据了,但是不能返回传递给其他变量!

 function getid(id)
    {
        var xmlhttp;

        if (window.XMLHttpRequest)
        {// code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp=new XMLHttpRequest();
        }
        else
        {// code for IE6, IE5
            xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
        }

        xmlhttp.onreadystatechange=function()
        {
            if (xmlhttp.readyState==4 && xmlhttp.status==200)
            {
                resultdata=xmlhttp.responseText;

}
        }
        xmlhttp.open("GET","getId.php?id="+id,true);
        xmlhttp.send();
         return resultdata;  //这样获取不到数据
    }

3个回答

一般是不会的,我遇到过这样的问题!我的解决办法是,先赋值给HTML,然后再通过js获取。希望有大牛分析,为什么会这样。

xiaoseqingchun
Winney_x 不要用return 因为ajax是异步的。ajax有一个.then在里面写你要执行的function
接近 5 年之前 回复
 xmlhttp.open("GET","getId.php?id="+id,true);
 改成
 xmlhttp.open("GET","getId.php?id="+id,false);
danielinbiti
danielinbiti 回复xfyanmeng: 技术就是拿来用的,该同步就同步,也没什么严重的影响。当然如果能采用异步方式是最好的。
接近 5 年之前 回复
xfyanmeng
xfyanmeng 我是新手,看得教程说不推荐这么做,有影响吗?
接近 5 年之前 回复
xfyanmeng
xfyanmeng 我是新手,看得教程说不推荐这么做,有影响吗?
接近 5 年之前 回复

又这么复杂吗? ajax执行成功后返回一个函数,把data带过去不就好了嘛?

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
ajax请求返回数据保存为全局变量
我发送ajax请求,想要将返回值保存到全局变量(因为其他js需要用到),我在function前面声明了全局变量, 在ajax中赋值,但是在其他js中调用该返回值,显示undifined
关于JS变量赋值的问题
我在JS文件的最顶部定义了一个变量var totaPage=0; 然后执行了一个ajax,在回调函数里想个totaPage赋值应该怎么写 success:function(data){ totaPage=data.totapage; } 我这样些不行
js全局变量的赋值和使用
var myArray = {}; var cpuNumMax = 1; var cpuNumMin = 1; function getVMProductByTypeMap(){ $.ajax({ url:"<%= request.getContextPath()%>/service/selfservice/getProductByTypeMap", type:"post", dataType:"json", data:{"typeId":"1"}, cache: false, asycn:false, success: function (data) { if(data != null && data != ""){ alert(data[0].cpuNumMax);////查到的值是32 cpuNumMax = parseInt(data[0].cpuNumMax); cpuNumMin = parseInt(data[0].cpuNumMin); for(var i=0; i<data.length; i++){ var memMax = data[i].memMax; var memMin = data[i].memMin; var cpuNum = data[i].cpuNum; myArray[cpuNum] = memMin+"|"+memMax; } } return resultFlag; //console.log(myArray); }, error:function(){ alert("error"); } }); } $(document).ready(function(){ getVMProductByTypeMap(); console.log(cpuNumMax); //1 }); ajax中我已使用了同步,但 为什么console.log(cpuNumMax); 输出是1,就是ajax中没有为其赋值 ?
做ajax请求时callback函数调用时this变量的变化问题
代码大致如下 [code="javascript"] var a = (function(){ var a = function (...,param) { return new a.fn.init (...,param) } a.fn = a.prototype = { init: function (...) { ... this.param = param } callback: function (response) { this.param //这里似乎this发生改变,this.param值为undefined ... } getData: function() { //通过ajax获得数据,然后回调 callback doGetAjax(url,data,this.callback) } } a.fn.init.prototype = a.fn; })() [/code] 像这种地方想要在callback获得param应该怎么做? edit1 -------------------------------------- 想了一下,这里ajax返回调用的时候this已经没有绑定了,在a内找不到再次与this绑定的方法, 那就不使用this,使用函数类的局部全局变量达到私有变量的效果, 代码改变如下 :[code="javascript"] var a = (function(){ var pParam; //添加私有变量 ... init: function (...) { ... pParam=this.param = param } ... callback: function (response) { pParam //这里似乎this发生改变,this.param值为undefined ... } [/code] 想了一下,是否所有对象的属性都应该赋值给 私有变量,而 this.XXX则是要暴露给外界才多加一个赋值? edit 2 ------------------------- 这两天重新看了下,发现这种私有变量是所有实例共享的,一个页面有多个同类组件的话就不行了. 如果是存储一个共享私有变量,每次ajax请求以后都手动立刻将私有变量赋值给相应实例变量,但这样的缺点是多次自动进行ajax操作的话是实现不了的,比如分页ajax请求。 这种情况究竟咋解决.
js全局变量的问题,大神来战
![图片说明](https://img-ask.csdn.net/upload/201708/16/1502871332_193057.png) ky是我定义的一个全局变量是这个形式的 var ky=[]; 因为在js下面有个插件有这个东西data: [5000, 2000,4060, 1000, 1000, 2000,4500,2000,ky[0],ky[1],], ky需要在后台获取,第一个function赋值成功,在页面也能显示,现在有个查询功能,所以第二个是ajax是带有条件的查询,能接收到后台传第回来的值,问题是付给全局变量不管用,页面不变,请问是怎么回事? 谢谢
js 一个全局变量,在一个函数中进行赋值,调用另一个函数 ,这个全局变量的值却没有值为undined
``` var typer; function zhe(){ typer = 'spline'; search(); } function search() { var jsonXData = []; var jsonyD = []; $.ajax({ url : base + '/gateBrandCount/statisticsbySpecial.html', data : $('#form').serialize(), success : function(e) { var json = eval("(" + e + ")"); for (var i = 0; i < json.length; i++) { var specialName = json[i].specialName; var count = json[i].count; jsonXData.push(specialName); // 赋值 jsonyD.push(count); } console.log(typer); if(typer==undefined){ console.log(typer+"11111") var op=highchart(jsonXData,jsonyD); op.chart.type='column'; }else{ console.log(typer+"22222") var op=highchart(jsonXData,jsonyD); op.chart.type="'"+typer+"'"; } console.log(op.chart.type+" ty"); chart = new Highcharts.Chart(op); } }) } ``` highchart为一个显示柱状图的函数 返回options 就是那个typer 调用zhe() ,赋值后在search()中就是undefined 求教啊
关于JS、AJAX程序逻辑、结构问题。
假如: 我用ajax取到一组数据 data 我需要根据data.length 创建 相应长度的表格 然后给表格的td赋值。 然后根据某个td 为 TR赋值。 那么! 当我要这些数据在每分钟刷新一次的时候。(只刷新数据) 那么表格也会再次重新创建。 问题:如何避免表格的重新创建! 我暂时的想法是:定义个变量a,在创建表格前做一次判断,执行后改变a的值。 这样做可以吗?如果可以,还有没有其他的方式方法?
关于js匿名函数的返回值的获取问题
我还在读js的基础书籍,所以对一些js原理了解不是全面,所以问题如有愚昧,还请见谅。 ``` function asynSubmit(sData,action,method="POST"){ var httpRequest = new XMLHttpRequest(); var rMessage="请求未发送"; httpRequest.open(method,action); httpRequest.setRequestHeader("content-type","application/x-www-form-urlencoded"); httpRequest.send(sData); httpRequest.onreadystatechange=function(){ if(httpRequest.readyState===4){ console.log("4"); if(httpRequest.status===200){ console.log("200"); var rData=httpRequest.responseText; //JSON.parse(httpRequest.responseText); return rData; }else{ return "服务器异常"; } }else{ return "服务器未响应"; } } } ``` 如上述代码,我想封装一个ajax的函数。想让函数返回responseText的值,因为onredeaychang调用了匿名函数,在匿名函数里返回的值我要怎么在外层函数获取?或者有其他什么方法能达到我的目的?我也试过在外层函数定义变量,在匿名函数里为变量赋值,但由于匿名函数绑定了事件,所以这样做直接返回空值。 自己想了很久,也百度过了,实在想不出解决办法,还请各位不吝赐教。
jquery+ajax写的分页,如何进行下一页和最后一页页数的限定,求大神
jquery-1.11.3.min.js. 自己写的分页js:pageTable.js ``` var commonURL = 'http://192.168.1.101:8088/main/cxtest?serviceName=';//公用jsonp请求地址 var serviceName = '';//服务名称--需要预先定义 var tableId;//table DOM id var PAGE_TOTAL_ROW_SIZE = 'page_total_row_size';//数据库返回的数据总条目数 var ROWNO = 'rowno';//数据库返回的行编号 //var testURL='http://192.168.109.157:8080/main/cxtest?'; var rowSize;//总数据条目数 var pageSize = 10;//每页条数,默认为10条 var currentPageIndex=1;//当前的页,默认为第一页 var pageNum;//总页数 //根据table的id动态加载数据 function loadTable(data) { cleanTable();//清除table除表头的内容 var tableCellHtml = ''; //遍历data,获取key和value for (var i = 0; i < data.length; i++) { var lineStr = '<tr>'; for (var key in data[i]) { if (PAGE_TOTAL_ROW_SIZE == key) { //对数据总数的返回值不做DOM处理 rowSize = data[i][key];//对数据总条目数赋值 continue; } //alert(key + ':' + data[i][key]); lineStr += '<th>' + data[i][key] + '</th>'; } lineStr += '</tr>'; tableCellHtml += lineStr; } getPageNum(); $("#"+tableId).append(tableCellHtml);//加载table数据 $("#spanCurrentPageIndex").html(currentPageIndex);//加载当前页码 $("#spanTotalPage").html(pageNum);//加载总页数 $("#spanTotalRowCount").html(rowSize);//加载总数据条目数 } //通用查询jsonp并返回数据到全局变量data function jsonpQuery(params) { $.ajax({ url: commonURL + serviceName + params, dataType: 'jsonp', type: 'GET', jsonp: 'jsonpcallback', error: function (XmlHttpRequest, textStatus, errorThrown) { alert("加载失败,请检查连接!"); }, success: function (msg) { if ('成功' == msg.message) { //alert(msg.message); data = eval('(' + msg.datas + ')'); loadTable(data); } else { alert("数据返回失败!"); } } }); } //根据总条数rowSize和每页条数pageSize获取总页数 function getPageNum() { if (checkVar(rowSize) && checkVar(pageSize)) { pageNum = rowSize % pageSize == 0 ? parseInt(rowSize / pageSize) : Math.ceil(rowSize/pageSize); } } //判断一个变量是否为空;true不为空,false为空 function checkVar(obj) { if (obj == '' || obj == undefined || obj == null) { return false; } return true; } //上一页或下一页 function pageNav(currentPageIndex){ //alert(currentPageIndex); var params = '&rowStart='+((currentPageIndex-1)*pageSize+1)+'&rowEnd='+currentPageIndex*pageSize; if(currentPageIndex<=0){ firstPage(); return ; } if(currentPageIndex>=pageNum){ lastPage(); return; } jsonpQuery(params);//请求数据 } //第一页 function firstPage(){ var params = '&rowStart=1&rowEnd='+pageSize; jsonpQuery(params);//请求数据 } //最后一页 function lastPage(){ var params = '&rowStart='+((pageNum-1)*pageSize+1)+'&rowEnd='+rowSize; jsonpQuery(params);//请求数据 } //清除表格内容 function cleanTable(){ $("#"+tableId+" tr:gt(0)").remove(); } ``` 下面是页面内容: ``` <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>table分页查询示例</title> </head> <body> <div> <table class="tablebox" width="" border="" cellpadding="" cellspacing="" id="tableInfo"> <tr> <td>序号</td> <td>流程ID </td> <td>流程名称</td> <td>流程标识 </td> <td>流程起始标识</td> </tr> </table> <div> <span id="spanFirst" onclick ="firstPage();" >第一页</span> <span id="spanPre" onclick ="pageNav(--currentPageIndex);">上一页</span> <span id="spanNext" onclick ="pageNav(++currentPageIndex);">下一页</span> <span id="spanLast" onclick ="lastPage();">最后一页</span> 第<span id="spanCurrentPageIndex"></span>页/共<span id="spanTotalPage"></span>页 共<span id="spanTotalRowCount"></span>条数据 </div> </div> <script type="text/javascript" src="JS/pageTable.js"></script> <script type="text/javascript" src="JS/jquery-1.11.3.min.js"></script> <script type="text/javascript"> $(function() { serviceName = 'getInfo'; tableId = 'tableInfo'; firstPage(); }); </script> </body> </html> ``` 现在就是有个问题,无法对下一页和最后一页进行限定,第一页的时候,我点击最后一页, 第1页/总页数,而且最后一页之后,点击下一页,第X页还是会增加,虽然说内容不变。
JS一个var如何接受后台传回json数据
easyUI有个demo上面是这样的 ``` <script> var products = [ {productid:'FI-SW-01',name:'Koi'}, {productid:'K9-DL-01',name:'Dalmation'}, {productid:'RP-SN-01',name:'Rattlesnake'}] <script> ``` ``` <body> <th field="productid" width="100" formatter="productFormatter" editor="{type:'combobox',options:{valueField:'productid',textField:'name',data:products,required:true}}">Product</th> </body> ``` 就是一个下拉选有3个选项,Koi、Dalmation和Rattlesnake,现在说我的下拉选的选项需要从后台获取数据,那么我想要这个var products = 后台获得的json数据,怎么做?就是一个json数据赋值给JS变量问题,我试过在函数里面定义一个var接受json数据但是不行。如下: ``` $.ajax({ url:'${pageContext.request.contextPath}/AjaxRegistration_list' }) .done(function(response){ console.log("success"+JSON.stringify(response)); var products = JSON.stringify(response); //这里能打印出json数据,但是上面的var products好像并不能被th中的editor使用data:products这样接受 alert(products); }) .fail(function(){ console.log("error") }); ```
为什么 CKediter 4.3.2 版本 赋值 有时会失败
> Blockquote .NET web 程序, 我从服务段序列化数据源为json 到某变量 json_Model,在前段 赋值给一 js 对象。然后绑定到 ckediter 容器,打开页面 刷新,查看ckediter赋值情况,有时候就可以,有时候就失败,为什么呢? 备注: 这段代码 是在页面最底部 </body> 之前,前边已经引用了 ckediter 的库文件,请忽略序列化失败问题,因为我尝试了 在某个 div 内同时赋值,是成功的。另外,火狐里边是没问题了。ie8 有问题,时好时坏。 <script> CKEDITOR.disableAutoInline = true; //var editor = CKEDITOR.replace("Description"); var json = {"ContentID":10,"Title":"公司简介","SubTitle":null,"Summary":"公司简介","Description":"&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; 于绿色建筑和智慧能源的发展,保护资源,保护环境,为合作伙伴和客户创造长期的价值,提供高品质高价值的产品和技术咨  询、技术培训、系统设计及工程实施等服务。新锘威智能科技将始终致力于绿色建筑和智慧能源的发展,保护资源,保护环境,为合作伙伴和客户创造长期的价值,提供高品质高价值的产品和技术咨询、技术培训、系统设计、工程实施等服务。","ImageUrl":null,"ThumbImageUrl":null,"NormalImageUrl":null,"CreatedDate":"\/Date(1389618017463)\/","CreatedUserID":1,"LastEditUserID":1,"LastEditDate":"\/Date(1390578846707)\/","LinkUrl":null,"PvCount":0,"State":true,"ClassID":41,"Keywords":null,"Sequence":0,"IsRecomend":false,"IsHot":true,"IsColor":false,"IsTop":true,"Attachment":null,"Remary":null,"TotalComment":0,"TotalSupport":0,"TotalFav":0,"TotalShare":0,"BeFrom":null,"FileName":null,"Meta_Title":"","Meta_Description":"","Meta_Keywords":"","SeoUrl":"","SeoImageAlt":null,"SeoImageTitle":null,"StaticUrl":null} $(function () { $('#Description').ckeditor(); $('#Description').val(json.Description); });</script>
easyui datagrid 编辑行后如何保存
<script type="text/javascript"> $(function () { var datagrid; //定义全局变量datagrid var editRow = undefined; //定义全局变量:当前编辑的行 datagrid = $("#dd").datagrid({ url: 'UserCenter.aspx', //请求的数据源 iconCls: 'icon-save', //图标 pagination: true, //显示分页 pageSize: 15, //页大小 pageList: [15, 30, 45, 60], //页大小下拉选项此项各value是pageSize的倍数 fit: true, //datagrid自适应宽度 fitColumn: false, //列自适应宽度 striped: true, //行背景交换 nowap: true, //列内容多时自动折至第二行 border: false, idField: 'ID', //主键 columns: [[//显示的列 {field: 'ID', title: '编号', width: 100, sortable: true, checkbox: true }, { field: 'UserName', title: '用户名', width: 100, sortable: true, editor: { type: 'validatebox', options: { required: true} } }, { field: 'RealName', title: '性别', width: 100, editor: { type: 'combobox', options: { data: [{ id: 0, text: '请选择' }, { id: 1, text: '男' }, { id: 2, text: '女' }], valueField: 'id', textField: 'text', } } }, { field: 'Email', title: '邮箱', width: 100, editor: { type: 'validatebox', options: { required: true} } } ]], queryParams: { action: 'query' }, //查询参数 toolbar: [{ text: '添加', iconCls: 'icon-add', handler: function () {//添加列表的操作按钮添加,修改,删除等 //添加时先判断是否有开启编辑的行,如果有则把开户编辑的那行结束编辑 if (editRow != undefined) { datagrid.datagrid("endEdit", editRow); } //添加时如果没有正在编辑的行,则在datagrid的第一行插入一行 if (editRow == undefined) { datagrid.datagrid("insertRow", { index: 0, // index start with 0 row: { } }); //将新插入的那一行开户编辑状态 datagrid.datagrid("beginEdit", 0); //给当前编辑的行赋值 editRow = 0; } } }, '-', { text: '删除', iconCls: 'icon-remove', handler: function () { //删除时先获取选择行 var rows = datagrid.datagrid("getSelections"); //选择要删除的行 if (rows.length > 0) { $.messager.confirm("提示", "你确定要删除吗?", function (r) { if (r) { var ids = []; for (var i = 0; i < rows.length; i++) { ids.push(rows[i].ID); } //将选择到的行存入数组并用,分隔转换成字符串, //本例只是前台操作没有与数据库进行交互所以此处只是弹出要传入后台的id alert(ids.join(',')); } }); } else { $.messager.alert("提示", "请选择要删除的行", "error"); } } }, '-', { text: '修改', iconCls: 'icon-edit', handler: function () { //修改时要获取选择到的行 var rows = datagrid.datagrid("getSelections"); //如果只选择了一行则可以进行修改,否则不操作 if (rows.length == 1) { //修改之前先关闭已经开启的编辑行,当调用endEdit该方法时会触发onAfterEdit事件 if (editRow != undefined) { datagrid.datagrid("endEdit", editRow); } //当无编辑行时 if (editRow == undefined) { //获取到当前选择行的下标 var index = datagrid.datagrid("getRowIndex", rows[0]); //开启编辑 datagrid.datagrid("beginEdit", index); //把当前开启编辑的行赋值给全局变量editRow editRow = index; //当开启了当前选择行的编辑状态之后, //应该取消当前列表的所有选择行,要不然双击之后无法再选择其他行进行编辑 datagrid.datagrid("unselectAll"); } } } }, '-', { text: '保存', iconCls: 'icon-save', handler: function () { //保存时结束当前编辑的行,自动触发onAfterEdit事件如果要与后台交互可将数据通过Ajax提交后台 datagrid.datagrid("endEdit", editRow); } }, '-', { text: '取消编辑', iconCls: 'icon-redo', handler: function () { //取消当前编辑行把当前编辑行罢undefined回滚改变的数据,取消选择的行 editRow = undefined; datagrid.datagrid("rejectChanges"); datagrid.datagrid("unselectAll"); } }, '-'], onAfterEdit: function (rowIndex, rowData, changes) { //endEdit该方法触发此事件,保存代码是否这里写??? //还需要判断combobox是否选中性别,而不是默认值 console.info(rowData); editRow = undefined; }, onDblClickRow: function (rowIndex, rowData) { //双击开启编辑行 if (editRow != undefined) { datagrid.datagrid("endEdit", editRow); } if (editRow == undefined) { datagrid.datagrid("beginEdit", rowIndex); editRow = rowIndex; } } }); }); </script> 1、怎么提交保存? 2、怎么在保存提交的时候判断combobox选中的不是“请选择”
JSp+ajax用户登录验证
[img]http://dl2.iteye.com/upload/attachment/0088/2001/4ee085e5-47e0-3995-ad42-62e4a53cfc2f.png[/img] 用户登陆界面,想要实现输入账号之后离开输入框就验证该账号是否存在,输入角色、账号、密码之后,点击登录,如果正确就跳转到index.jsp,错误不跳转并且在密码输入框下显示提示信息;有一个没输入就提示,信息也是在密码输入框下。 我现在的问题是:若果什么也不输,点击登录,会闪一下,但闪过之后就是重置了页面。输入正确也是闪一下就重置页面.账号验证没问题,就是登录有问题,但是搞不定,大侠们看看吧! login.jsp [code="java"]<form id="form" name="form" method="post" action="" > <table border="0"> <tr> <td align="right">角色类型:</td> <td><select name="role" id="role" onBlur="checkRole(this)"> <option value="0">-请选择角色-</option> <% List<Role> list = new ArrayList<Role>(); RoleDao dao = new RoleDaoImpl(); list = dao.findAllRoles();//调用实现类的查询全部方法 for (int i = 0; i < list.size(); i++) { Role r = list.get(i); %> <option value="<%=r.getR_id()%>"><%=r.getR_name()%></option> <% } %> </select> </td> <td align="left"> &nbsp; <span id="roleSpan"></span> </td> </tr> <tr> <td align="right">账号:</td> <td> <input type="text" name="number" id="number" onblur="checkNumber(this)"> </td> <td width="256" align="left"> &nbsp; <span id="numberSpan"></span> </td> </tr><!-- 当输入名字后离开输入框即调用--> <tr> <td align="right">密码:</td> <td><input type="password" name="pwd" id="pwd" onBlur="checkPsw(this)" > </td> <td align="left"> &nbsp; <span id="pwdSpan"></span> </td> </tr> <tr> <td align="left">&nbsp;<span id="feedback_info"></span></td> </tr> <tr> <td colspan="1"> <input type="submit" value="登录" onclick="checkLogin(this.form)"/> <input type="button" value="注册" onclick="javascript:window.location.href='User/Register.jsp'"></td> </tr> </table> </form>[/code] login.js [code="java"]var xmlHttp; function createXMLHttpRequest() { if (window.XMLHttpRequest) { var xmlHttp = new XMLHttpRequest(); //mozilla浏览器 } else if (window.ActiveXObject) { try { var xmlHttp = new ActiveX0bject("Msxml2.XMLHTTP"); //IE老版本 } catch (e) { } try { var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); //IE新版本 } catch (e) { } } if (!xmlHttp) { window.alert("不能创建XMLHttpRequest对象实例"); return false; } else return xmlHttp; ////}///////花括号放错地方 } // 检查账号,给出提示信息 function checkNumber(Number) { var numberSpan = document.getElementById("numberSpan"); if (Number.value == "") { numberSpan.innerHTML = "账号必须填写".fontcolor("red"); return false; } else { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckNumberServlet?number="+Number.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange1; xmlHttp.send(null); return true; } } function handleStateChange1() { var numberSpan = document.getElementById("numberSpan"); if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { // alert("来自服务器的响应:"+xmlHttp.responseText); if (xmlHttp.responseText == 'true') {///////responseText是字符串,不能和boolean变量直接比较 // alert("存在"); numberSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } else if (xmlHttp.responseText == 'false') {///////responseText是字符串,不能和boolean变量直接比较 // alert("不存在"); numberSpan.innerHTML = "账号不存在".fontcolor("red"); return false; } } else alert("服务器端错误"); } } // 检查密码,给出提示信息 function checkPsw(pswNode) { var spanNode1 = document.getElementById("pswSpan"); var Role= document.getElementById("role"); var Number= document.getElementById("number"); if (pswNode.value == "") { spanNode1.innerHTML = "密码必须填写".fontcolor("red"); return false; } else { pwdSpan.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查是否选中角色 function checkRole(selNode) { var index = selNode.selectedIndex;// 获得选中下标 var spanNode1 = document.getElementById("roleSpan"); if (index <= 0) { spanNode1.innerHTML = "必须选择角色".fontcolor("red"); return false; } else { spanNode1.innerHTML = "<img src='Img/g.gif'>"; document.getElementById("feedback_info").innerHTML=""; return true; } } // 检查表单 function checkLogin(o) { var Role=o.role; var Number= o.number; var Pwd= o.pwd; if(checkNumber(Number)&&checkPsw(Psw) &&checkRole(Role)) { xmlHttp = createXMLHttpRequest(); //createXMLHttpRequest申明的是局部变量,这里访问不到xmlHttp,要给xmlHttp变量赋值才行 var url="servlet/CheckLoginServlet?number="+Number.value+"&role="+Role.value+"&pwd="+Pwd.value+"&LoginTime="+new Date().getTime(); url = encodeURI(url); //转换码后再传输 xmlHttp.open("GET",url,true);//加时间戳防止IE缓存 //xmlhttp.setRequestHeader( "Content-Type", "text/html;charset=UTF-8" ); xmlHttp.onreadystatechange = handleStateChange2; xmlHttp.send(null); return true; } else{ document.getElementById("feedback_info").innerHTML="请填写每一项".fontcolor("red"); return false; } } function handleStateChange2() { if (xmlHttp.readyState == 4) { if (xmlHttp.status == 200) { //alert("来自服务器的响应:" + xmlHttp.responseText); if(xmlHttp.responseText == '0'){ document.getElementById("feedback_info").innerHTML="账号与密码不匹配".fontcolor("red"); return false; } else if(xmlHttp.responseText == '1'){ document.getElementById("feedback_info").innerHTML=""; window.location.href="index.jsp"; return true; } } else alert("服务器端错误"); } }[/code] chuckLoginservlet [code="java"]public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html"); doPost(request, response);// 调用doPost方法 } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); response.setContentType("text/html;charset=UTF-8"); String number=""; try { number = new String(request.getParameter("number").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e1) { System.out.println("number为空"); } String role="0"; int rID=0; try { role = new String(request.getParameter("role").getBytes( "ISO-8859-1"), "UTF-8"); rID=Integer.parseInt(role);//把获得的role的值转成整型 } catch (Exception e1) { System.out.println(request.getParameter("role")+"******role"); } String pwd=""; try { pwd = new String(request.getParameter("pwd").getBytes( "ISO-8859-1"), "UTF-8"); } catch (Exception e) { System.out.println(request.getParameter("pwd")+"****pwd"); } // String txt = new String(number.getBytes("ISO-8859-1"), "UTF-8"); // System.out.println(txt+"********"); PrintWriter out = response.getWriter(); User u = new User(); UserDao ud = new UserDaoImpl(); u = ud.findUserByNumber(number);//通过账号找到用户对象 if (u != null) {// 找到该用户 int u_id = u.getU_id();// 获得该用户的ID UserRole ur = new UserRole(); UserRoleDao urd = new UserRoleDaoImpl(); ur = urd.findUserRoleByUserId(u_id);// 找到中间表UserRole的记录 int r_id = ur.getRole().getR_id();// 由Userrole表找到Role表的相对应角色名称 if (r_id==rID && u.getU_password().equals(pwd))// 如果数据中的角色和密码与之对应 { out.write("1");//1表示验证通过 } else { out.write("0");//0表示密码与账号不匹配 } } out.flush(); out.close(); }[/code]
一个js问题 ,我要在这个地方做一个跳转到a标签的代码,在网上找了半天也没找到
``` $.ajax({ type : 'POST', url : '${stx }/oa/knowledge/downloadCount', data : params, dataType : 'json', timeout : 5000, context : $('body'), success : function(data) { var status = data.status; if (status == 'success') { /***************************************************** 在这个地方添加跳转A标签的代码(<a id=downloadfile href="下载地址" download=''></a>)下载地址是由前边的变量赋值. 我之前也做了,但是出现问题了。第一次赋值,没问题。但是第二次就不会覆盖第一次的,也就是说下载地址没变还是第一次的地址并且a标签里的download属性不起作用了我用的是location.replace("#downloadfile").attr("href") 并且A标签是放在js外 *********************************************************/ } else { alert(data.message); } }, error : function( XMLHttpRequest, textStatus, errorThrown) { alert("服务器错误,请稍后重试!"); } }); ```
使用DWR出现奇怪问题
最近做项目,使用DWR的时候遇到了一个莫名其妙的问题: 需求:博客系统,当用户浏览某个博客首页的时候列出博主文章的标题列表,并且列出文章的回复数,由于回复在另外一个表中,需要查询count(*)获取。我的实现是,先列出文章标题,再用DWR获取各个文章的回复数(生成一个文章标题就生成一个ReplyCountUtil.replyCountUtil(id)方法获取回复数) JS对象配置: [code="java"]<create creator="spring" javascript="ReplyCountUtil" scope="request"> <param name="beanName" value="replyCountUtil" /> <include method="getArtCount" /> </create>[/code]给getArtCount方法传进去一个文章的ID,返回文章的回复数。 问题是:当页面加载完成后,DWR读取的回复数总是一样的(即第一篇文章的回复数),好像其他的getArtCount()就没有执行?? 为什么... 是不是我这种实现方式也有问题? [b]问题补充:[/b] 前台jsp是这样的,因为太多,我简化了一下: [code="java"]<ul class="archives"> <!-- 循环文章标题start --> <c:forEach items="${list}" var="article" varStatus="Status"> <li> <h3> 标题:<a href="#" target="_self">${article.name }</a> 回复:<span id="article_${article.id }"><script type="text/javascript" defer="defer">getNums(${article.id });}</script></span>条 </h3> </li> </c:forEach> <!-- end --> </ul>[/code] 页面加载完毕后执行getNums方法获取数量: [code="java"]<script type="text/javascript"> //获得文章的回复数 function getNums(id) { var obj = document.getElementById('article_'+year); obj.innerHTML = ""; //调用ReplyCountUtil类的getArtCount方法,根据Id获取文章的回复数 ReplyCountUtil.getArtCount(id,function (data) {setNums(id,data)}); } //innerHTML到<span> function setNums(id,data) { var obj = document.getElementById('article_'+id); obj.innerHTML = data;//data 文章的回复数 } </script>[/code] ReplyCountUtil类的getArtCount方法不用再贴出来了吧,就是通过DAO,执行sql的count()计算文章的回复数。 [b]问题补充:[/b] 还是有问题,估计是dwr在多个相同的方法并行执行时变量有问题? 另外问下:一般像博客、论坛系统取回帖数是怎么去的,谢谢~~ [b]问题补充:[/b] 请问 lovewhzlq 一般像博客、论坛首页当列出标题后,是怎么读取回帖数、浏览量的,谢谢~~ [b]问题补充:[/b] 是一次全部取出赋值,还是像我的实现那样生成多个ajax方法, 最后一个问题,谢谢
Grid 下拉列表问题
我从后台返回一个数据集 用Grid显示 其中性别 职务都是数字 是字典ID 我打算在deferer的时候 将数字更新为汉字 [code="java"] //-->数据列 var Employee_cm = new Ext.grid.ColumnModel ([ ...... {header:'性别',dataIndex:'SexID',width:100,editor:Employee_SexCombox, renderer:function(value, cellmeta, record, rowIndex, columnIndex, store){ return GetDictionaryNameByID(record.data["SexID"]); } }, ]); //翻译字典的公共函数 function GetDictionaryNameByID(DictionaryID) { Ext.Ajax.request ({ url : 'JSON/System/Dictionary.aspx', params: { FunctionName : 'Sys_Dictionary_GetDictionaryName', DictionaryID : DictionaryID }, failure : function(response,option) { return ''; }, success : function(response,option) { if (Ext.util.JSON.decode(response.responseText).success) { var temp_infoObject = Ext.util.JSON.decode(response.responseText); return temp_infoObject.info; } else { return ''; } } }) } [/code] 但是 我发现grid每次翻译后都是空 后台返回值用FireBug调试是:{success:true,info:"男"} 请教一下大家为什么?如果我把GetDictionaryNameByID返回值写死 就可以翻译成功。。。。 [b]问题补充:[/b] Rooock: 我用调试了 数据取到后台 没有问题 蔡华江: record.data["SexID"]); 我这样写 可以取得数据 record.get("SexID"); 反倒不能得到数据 会后台报错 大家平时是怎么解决Grid字典项翻译的?也说一下 谢谢 [b]问题补充:[/b] Rooock: // 你是说这里temp_infoObject.info是男. 但是显示不了? return temp_infoObject.info; 是的 程序有运行到这里 但是最终 GetDictionaryNameByID(DictionaryID)函数返回值时空 如果我在GetDictionaryNameByID 一开始就声明一个变量StrRetrun = 在各个return的地方 给这个变量赋值 最后返回 StrRetrun变量 就发现 最终grid显示的是'ddd' 但是在FF中调试 发现确实在success : function(response,option) 的时候 给StrRetrun赋过'男'的。。。。 [b]问题补充:[/b] 蔡华江: 原来是这样 我在原理上就错误了 没有理解正确 谢谢。 请问 你是怎么解决这个问题的呢? 翻译Grid中的字典项 最好能贴段代码 小弟这里谢过
datagrid 表中的 怎么去限制俩个datetimebox 的大小
表结构<br/>![图片说明](https://img-ask.csdn.net/upload/201610/07/1475825320_194509.png) 我想让datetimebox A 如果选择了 2016-8-8 那么 datetimebox B就不能进行选 8-8之前的日期了 只能比它大,反之亦然,A不能比B大! 表格代码是这样的 <br/> html部分 ``` <table id="dg" rownumbers="true" class="easyui-datagrid" style="width:100%;height:auto;" data-options="onEndEdit:onEndEdit,onLoadSuccess:compute"> <thead> <tr> <th data-options="field:'ck',width:100,checkbox:true"></th> <th data-options="field:'dept_id',width:100,formatter:function(value,row){return row.dept_name; },editor:{ type:'combobox',options:{ valueField:'dept_id', textField:'dept_name',method:'get',url:'{$json}', } }">开单部门</th> <th data-options="field:'to_dept',width:100, formatter:function(value,row){ return row.todeptname;},editor:{ type:'combobox',options:{ valueField:'dept_id', textField:'todeptname',url:'{$json2}', editable:false }}">目标分店</th> <th data-options="field:'so_date',width:160,editor:{type:'datetimebox',options:{editable:false,}}">发生日期</th> <th data-options="field:'income',width:100,editor:{type:'numberbox',options:{}},formatter:function(value,row,index){ return formatNumber(value,2); }">借</th> <th data-options="field:'pay',width:100,editor:{type:'numberbox',options:{}}, formatter:function(value,row,index){ return formatNumber(value,2);}">贷</th> <th data-options="field:'record_date',width:160,editor:{type:'datetimebox',options:{editable:false}}">审核日期</th> </tr> </thead> </table> ``` JS部分 ``` <script> $(document).ready(function(){ var datagrid; //定义全局变量datagrid var editRow1 = undefined; //定义全局变量:当前编辑的行 datagrid1 = $("#dg").datagrid({ url:'{$recURL}', //请求的数据源 iconCls: 'icon-save', //图标 fit: false, //datagrid自适应宽度 fitColumn: false, //列自适应宽度 striped: true, //行背景交换 nowrap: true, //列内容多时自动折至第二行 border: false, idField: 'dept_id', //主键 //queryParams: { action: 'query' }, //查询参数 toolbar: [{ text: '添加一行', iconCls: 'icon-add', handler: function () { if (editRow1 != undefined) { datagrid1.datagrid("endEdit", editRow1); } if (editRow1 == undefined) { datagrid1.datagrid("insertRow", { index: 0, // index start with 0 row: { } }); //将新插入的那一行开户编辑状态 datagrid1.datagrid("beginEdit", 0); var insert_c= $('#dg').datagrid("getChanges",'updated'); var dg = $('#dg').datagrid('getEditor', { index: 0, field: 'dept_id' }); $(dg.target).combobox('select',"001"); //给当前编辑的行赋值 editRow1 = 0; } } }, '-', { text: '删除选中', iconCls: 'icon-remove', handler: function () { //删除时先获取选择行 var rows = datagrid1.datagrid("getSelections"); //选择要删除的行 if (rows.length > 0) { $.messager.confirm("提示", "你确定要删除吗?", function (r) { if (r) { var ids = []; var row = []; for (var i = 0; i < rows.length; i++) { var rowIndex = $('#dg').datagrid('getRowIndex', rows[i]);//获取指定行 row[i]=rowIndex; ids.push(rows[i].dept_id); } if($('#dg').datagrid('getRows').length==row.length){ editRow1 = undefined; datagrid1.datagrid("rejectChanges"); $.messager.alert("提示","删除成功","info"); }else{ for(var i=0;i<row.length;i++){ $('#dg').datagrid('deleteRow', row[i]); //删除指定行 } }//将选择到的行存入数组并用,分隔转换成字符串, } }); } else { $.messager.alert("提示", "请选择要删除的行","error"); } } }, '-', { text: '修改选中', iconCls: 'icon-edit', handler: function () { //修改时要获取选择到的行 var rows = datagrid1.datagrid("getSelections"); //如果只选择了一行则可以进行修改,否则不操作 if (rows.length == 1) { //修改之前先关闭已经开启的编辑行,当调用endEdit该方法时会触发onAfterEdit事件 if (editRow1 != undefined) { datagrid1.datagrid("endEdit", editRow1); } //当无编辑行时 if (editRow1 == undefined) { //获取到当前选择行的下标 var index = datagrid.datagrid("getRowIndex", rows[0]); //开启编辑 datagrid1.datagrid("beginEdit", index); //把当前开启编辑的行赋值给全局变量editRow1 editRow1 = index; datagrid1.datagrid("unselectAll"); } }else { $.messager.alert('警告', '修改必须或只能选择一行!', 'warning'); } } }, '-', { text: '保存', iconCls: 'icon-save', handler: function () { //保存时结束当前编辑的行,自动触发onAfterEdit事件如果要与后台交互可将数据通过Ajax提交后台 datagrid1.datagrid("endEdit", editRow1); } }, '-' , {text: '设置视图', handler: function (){ var s=$(this).parents("fieldset").find(".datagrid-header"); set_view(s); } },'-'], onAfterEdit: function (rowIndex, rowData, changes) { //endEdit该方法触发此事件 //console.info(rowData); editRow1 = undefined; compute(); }, onDblClickRow: function (rowIndex, rowData) { //双击开启编辑行 var cx; var insert_c= $('#dg').datagrid("getChanges",'inserted'); for(var i=0;i<insert_c.length;i++){ var row_l=$('#dg').datagrid("getRowIndex",insert_c[i]); if(rowIndex==row_l){ cx=true; } } if (editRow1 != undefined) { datagrid1.datagrid("endEdit", editRow1); } if (editRow1 == undefined) { var rows = $('#dg').datagrid('getRows'); if(cx){ datagrid1.datagrid("beginEdit", rowIndex); editRow1 = rowIndex; cx=false; }else{ datagrid1.datagrid("beginEdit", rowIndex); editRow1 = rowIndex; var dd = $('#dg').datagrid('getEditor', { index: rowIndex, field: 'dept_id' }); $(dd.target).combobox('disable'); } } } }); //编辑状态 function endEditing1() { if (editRow1 == undefined) { return true } if ($('#dg').datagrid('validateRow', editRow1)) { var ed = $('#dg').datagrid('getEditor', { index: editRow1, field: 'dept_id' }); $('#dg').datagrid('endEdit', editRow1); editRow = undefined; return true; } else { return false; } } }); function onEndEdit(index, row){ var ed = $('#dg').datagrid('getEditor', { index: index, field: 'dept_id' }); row.dept_name = $(ed.target).combobox('getText'); var ed1 = $('#dg').datagrid('getEditor', { index: index, field: 'to_dept' }); row.todeptname = $(ed1.target).combobox('getText'); } function compute(){ var rows = $('#dg').datagrid('getRows')//获取当前的数据行 var ptotal = 0//计算listprice的总和 ,utotal = 0//统计unitcost的总和 ,table = 0; for (var i = 0; i < rows.length; i++) { ptotal += parseFloat(rows[i]['income']) || 0 ; utotal += parseFloat(rows[i]['pay']) || 0 ; } table = ptotal - utotal; document.getElementById('payin').innerText=ptotal.toFixed(2).replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g, '$&,');//输出位置 document.getElementById("payout").innerText=utotal.toFixed(2).replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g, '$&,'); document.getElementById('payincome').innerText=table.toFixed(2).replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g, '$&,'); } function formatNumber(value, fixed) { var number = Number(value); return number.toFixed(2).replace(/\d{1,3}(?=(\d{3})+(\.\d*)?$)/g, '$&,'); }</script> ``` 因为他的是easyui组件,我不知道怎么去实现 这个需求
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
【JSON解析】浅谈JSONObject的使用
简介 在程序开发过程中,在参数传递,函数返回值等方面,越来越多的使用JSON。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,同时也易于机器解析和生成、易于理解、阅读和撰写,而且Json采用完全独立于语言的文本格式,这使得Json成为理想的数据交换语言。 JSON建构于两种结构: “名称/值”对的集合(A Collection of name/va...
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
2019年还剩1天,我从外包公司离职了
这日子过的可真快啊,2019年还剩1天,外包公司干了不到3个月,我离职了
我一个37岁的程序员朋友
周末了,人一旦没有点事情干,心里就瞎想,而且跟几个老男人坐在一起,更容易瞎想,我自己现在也是 30 岁了,也是无时无刻在担心自己的职业生涯,担心丢掉工作没有收入,担心身体机能下降,担心突...
计算机网络的核心概念
这是《计算机网络》系列文章的第二篇文章 我们第一篇文章讲述了计算机网络的基本概念,互联网的基本名词,什么是协议以及几种接入网以及网络传输的物理媒体,那么本篇文章我们来探讨一下网络核心、交换网络、时延、丢包、吞吐量以及计算机网络的协议层次和网络攻击。 网络核心 网络的核心是由因特网端系统和链路构成的网状网络,下面这幅图正确的表达了这一点 那么在不同的 ISP 和本地以及家庭网络是如何交换信息的呢?...
python自动下载图片
近日闲来无事,总有一种无形的力量萦绕在朕身边,让朕精神涣散,昏昏欲睡。 可是,像朕这么有职业操守的社畜怎么能在上班期间睡瞌睡呢,我不禁陷入了沉思。。。。 突然旁边的IOS同事问:‘嘿,兄弟,我发现一个网站的图片很有意思啊,能不能帮我保存下来提升我的开发灵感?’ 作为一个坚强的社畜怎么能说自己不行呢,当时朕就不假思索的答应:‘oh, It’s simple. Wait for me for a ...
一名大专同学的四个问题
【前言】   收到一封来信,赶上各种事情拖了几日,利用今天要放下工作的时机,做个回复。   2020年到了,就以这一封信,作为开年标志吧。 【正文】   您好,我是一名现在有很多困惑的大二学生。有一些问题想要向您请教。   先说一下我的基本情况,高考失利,不想复读,来到广州一所大专读计算机应用技术专业。学校是偏艺术类的,计算机专业没有实验室更不用说工作室了。而且学校的学风也不好。但我很想在计算机领...
复习一周,京东+百度一面,不小心都拿了Offer
京东和百度一面都问了啥,面试官百般刁难,可惜我全会。
Java 14 都快来了,为什么还有这么多人固守Java 8?
从Java 9开始,Java版本的发布就让人眼花缭乱了。每隔6个月,都会冒出一个新版本出来,Java 10 , Java 11, Java 12, Java 13, 到2020年3月份,...
达摩院十大科技趋势发布:2020 非同小可!
【CSDN编者按】1月2日,阿里巴巴发布《达摩院2020十大科技趋势》,十大科技趋势分别是:人工智能从感知智能向认知智能演进;计算存储一体化突破AI算力瓶颈;工业互联网的超融合;机器间大规模协作成为可能;模块化降低芯片设计门槛;规模化生产级区块链应用将走入大众;量子计算进入攻坚期;新材料推动半导体器件革新;保护数据隐私的AI技术将加速落地;云成为IT技术创新的中心 。 新的画卷,正在徐徐展开。...
轻松搭建基于 SpringBoot + Vue 的 Web 商城应用
首先介绍下在本文出现的几个比较重要的概念: 函数计算(Function Compute): 函数计算是一个事件驱动的服务,通过函数计算,用户无需管理服务器等运行情况,只需编写代码并上传。函数计算准备计算资源,并以弹性伸缩的方式运行用户代码,而用户只需根据实际代码运行所消耗的资源进行付费。Fun: Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算、API ...
讲真,这两个IDE插件,可以让你写出质量杠杠的代码
周末躺在床上看《拯救大兵瑞恩》 周末在闲逛的时候,发现了两个优秀的 IDE 插件,据说可以提高代码的质量,我就安装了一下,试了试以后发现,确实很不错,就推荐给大家。 01、Alibaba Java 代码规范插件 《阿里巴巴 Java 开发手册》,相信大家都不会感到陌生,其 IDEA 插件的下载次数据说达到了 80 万次,我今天又贡献了一次。嘿嘿。 该项目的插件地址: https://github....
Python+OpenCV实时图像处理
目录 1、导入库文件 2、设计GUI 3、调用摄像头 4、实时图像处理 4.1、阈值二值化 4.2、边缘检测 4.3、轮廓检测 4.4、高斯滤波 4.5、色彩转换 4.6、调节对比度 5、退出系统 初学OpenCV图像处理的小伙伴肯定对什么高斯函数、滤波处理、阈值二值化等特性非常头疼,这里给各位分享一个小项目,可通过摄像头实时动态查看各类图像处理的特点,也可对各位调参、测试...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
害怕面试被问HashMap?这一篇就搞定了!
声明:本文以jdk1.8为主! 搞定HashMap 作为一个Java从业者,面试的时候肯定会被问到过HashMap,因为对于HashMap来说,可以说是Java集合中的精髓了,如果你觉得自己对它掌握的还不够好,我想今天这篇文章会非常适合你,至少,看了今天这篇文章,以后不怕面试被问HashMap了 其实在我学习HashMap的过程中,我个人觉得HashMap还是挺复杂的,如果真的想把它搞得明明白...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
程序员如何通过造轮子走向人生巅峰?
前言:你所做的事情,也许暂时看不到成果。但不要灰心,你不是没有成长,而是在扎根。 程序员圈经常流行的一句话:“不要重复造轮子”。在计算机领域,我们将封装好的组件、库,叫做轮子。因为它可以拿来直接用,直接塞进我们的项目中,就能实现对应的功能。 有些同学会问,人家都已经做好了,你再来重新弄一遍,有什么意义?这不是在浪费时间吗。 殊不知,造轮子是一种学习方式,能快速进步,造得好,是自己超强能力的表...
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试一个ArrayList我都能跟面试官扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
Idea 中最常用的10款插件(提高开发效率),一定要学会使用!
学习使用一些插件,可以提高开发效率。对于我们开发人员很有帮助。这篇博客介绍了开发中使用的插件。
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
立即提问