js layui框架在ajax 未运行完就执行
 btn:['提交','取消'],
                yes:function(yes,no){
                    $.ajax({
                        url:'mvc/smUser00200002/addSmUser',
                        type:'post',
                        data:$('#updateform').serialize(),
                        dataType: "text",
                        success:function (obj) {
                            if(obj=='403'){
                                alert("请重新登录");
                                $("#tbody").html("");
                            }else if(obj=='201'){

                                $.ajax({
                                    url: 'mvc/smUser00200002/getSmUserAll',
                                    type: 'get',
                                    dataType: "json",
                                    success: function (obj) {
                                        if(obj.state=='403'){
                                            alert("请重新登录");
                                            $("#tbody").html("");
                                        }
                                        else {
                                            var number='';
                                            for(var j=1;j<obj.page+1;j++){
                                                number+=
                                                    '<a href="#" onclick="pagenumber('+j+')">'+j+'</a>'
                                            }
                                            var strb='';
                                            strb+=
                                                '<span class="l_f">'+
                                                '<a title="新建" onclick="add('+"'新建',"+"'"+nowuserid+"',"+"'smUser_new.html',"+"'"+nowuserid+"',"+"'950',"+"'550'"+')" class="btn btn-warning Order_form" ><i class="icon-plus"></i>新建人员信息</a>'+
                                                '</span>'+
                                                '<input type="button" onclick="pageupordown('+"'up'"+')" class="layui-btn" value="上一页" style="height: 40px;margin-left: 800px">'+
                                                number+
                                                '<input type="button" onclick="pageupordown('+"'down'"+')" class="layui-btn" value="下一页" style="height: 40px">';
                                            $("#buta").html(strb);

                                            var str='';

                                            for(var i=0;i<obj.smuser.length;i++){
                                                var mm= obj.smuser[i].faceImage;
                                                var s=mm.lastIndexOf("\\");
                                                var uri="img\\SmUser"+mm.substring(s);
                                                str+=
                                                    '<tr>'+
                                                    '<td width="70px">'+obj.smuser[i].userName+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].creator+'</td>'+
                                                    '<td width="180px">'+obj.smuser[i].creationtime+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].modifier+'</td>'+
                                                    '<td width="150px">'+obj.smuser[i].userType+'</td>'+
                                                    '<td width="180px">'+obj.smuser[i].phoneNum+'</td>'+
                                                    '<td width="200px">'+obj.smuser[i].addr+'</td>'+
                                                    '<td width="180px">'+obj.smuser[i].birthdate+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].edu+'</td>'+
                                                    '<td width="200px">'+obj.smuser[i].id+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].nationality+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].nativeplace+'</td>'+
                                                    '<td width="70px">'+obj.smuser[i].sex+'</td>'+
                                                    '<td width="100px">'+obj.smuser[i].titletechpost+'</td>'+
                                                    '<td width="100px">'+obj.smuser[i].addrCode+'</td>'+
                                                    '<td width="100px"><img src="'+uri+'" alt="" width="100px" height="100px"></td>'+
                                                    '<td width="200px">'+obj.smuser[i].note+'</td>'+
                                                    '<td width="80px" onclick="member_edit('+"'权限',"+"'smUser_power.html',"+"'"+obj.smuser[i].pkUser+"',"+"'550',"+"'550'"+')"><p style="text-decoration:underline;color: blue;cursor: pointer">权限</p></td>'+
                                                    '<td class="td-manage">'+
                                                    '<a title="编辑" onclick="add('+"'编辑',"+"'"+nowuserid+"',"+"'smUser_update.html',"+"'"+obj.smuser[i].pkUser+"',"+"'1000',"+"'550'"+')" class="btn btn-xs btn-info" ><i class="icon-edit bigger-120"></i></a>'+
                                                    '<a title="删除" href="javascript:;"  onclick="member_del(this,'+"'"+obj.smuser[i].pkUser+"'"+')" class="btn btn-xs btn-warning" ><i class="icon-trash  bigger-120"></i></a>'+
                                                    '</td></tr>';

                                            }
                                            $("#tbody").html(str);
                                        }
                                    }
                                });
                                alert("添加成功,但是没有人脸图片");
                                layer.close(layer.index);


                                                                框架是layui 弹出框弹出后点击提交触发ajax重写页面tbody
                                                                重写未执行完 data拿到了 ajax未执行完就弹窗和关闭弹出框

1个回答

ajax全部改成同步的,要么后面2句放到 $.ajax({
url: 'mvc/smUser00200002/getSmUserAll',的回掉里面

 yes:function(yes,no){
                    $.ajax({async:false,////////////改为同步
                        url:'mvc/smUser00200002/addSmUser',
                        type:'post',
                        data:$('#updateform').serialize(),
                        dataType: "text",
                        success:function (obj) {
                            if(obj=='403'){
                                alert("请重新登录");
                                $("#tbody").html("");
                            }else if(obj=='201'){

                                $.ajax({{async:false,////////////改为同步
                                    url: 'mvc/smUser00200002/getSmUserAll',
                                    type: 'get',
                                    dataType: "json",

或者

   for(var i=0;i<obj.smuser.length;i++){
                                       //原来的代码。。。。。。。。。。。。。

                                            }
                                            $("#tbody").html(str);
                                                                                        ////////////最后2句放这里来。去掉原来的那2句
                                                                                        alert("添加成功,但是没有人脸图片");
                                layer.close(layer.index);
showbo
支付宝加好友偷能量挖 回复yankYuki: 没注意看结构,第一个可以异步,第二个需要为同步或者放回掉里面,原因就是异步不会挂起后续代码的执行
接近 2 年之前 回复
showbo
支付宝加好友偷能量挖 回复yankYuki: 异步不会挂起后续代码的执行,所以发送完第一个ajax后直接执行后面2句了
接近 2 年之前 回复
yankYuki
yankYuki 我明天试试
接近 2 年之前 回复
yankYuki
yankYuki 是因为异步ajax为执行完不能执行下一个ajax吗;
接近 2 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
后台管理系统使用的layui框架,post请求提交时部分win10的谷歌浏览器会刷新页面
同win10浏览器,用同版本的浏览器并不会复现此bug, post请求后有添加return false,反正页面刷新, 单单就那台机子的谷歌浏览器和edge会出现, 请问有大佬遇到过吗
Layui框架的table的选中行功能,获取选中行数据为空!!有没有大佬帮忙看看啊,查了各种资料都不行!!!
``` <table class="layui-hide" id="user-index" lay-filter="user-index"></table> ``` ``` <script> layui.use(['layer', 'table'], function () { var $ = layui.$ , layer = layui.layer , form = layui.form , table = layui.table; //独立版的layer无需执行这一句 var tableId = 'user-index'; var tableToolbar = 'user-index-toolbar'; var tableSearchForm = 'user-index-search'; var minWidth = 768; // 表格渲染 table.render({ elem: '#' + tableId , toolbar: '#' + tableToolbar , defaultToolbar: ['filter'] // ['filter', 'print', 'exports'] , url: '/User/list' ,where:{'username':'','realname':'','tel':'','city':'','isdelete':0} , method: 'get' , cellMinWidth: 80 //全局定义常规单元格的最小宽度,layui 2.2.1 新增 , cols: [[ {type: 'checkbox', id:'cb',fixed: 'left'} , {field: 'id', width: 80, title: 'ID', sort: true} , {field: 'username', width: 212, title: '用户名', sort: true} , {field: 'realname', width: 100, title: '姓名'} , {field: 'sex', width: 105, title: '性别'} , {field: 'tel', width: 180, title: '手机号'} , {field: 'city', width: 120, title: '城市', sort: true} , {field: 'role', width: 100, title: '角色ID', sort: true} , { title: '状态', width: 150, templet: function (res) { if (res.status == '1') { return '已激活(使用中)'; } else { return '<span style="color: #F581B1;">冻结(过期请续费)</span>'; } } } ]] , page: true ,limit:7 , height: 'full-60' // 100 }); ``` 头工具栏的监听 ``` table.on('toolbar(' + tableId + ')', function (obj) { var checkStatus = table.checkStatus(obj.config.id) , data = checkStatus.data; console.log(data) //获取选中行的数据 ``` 结果我选中一条或者是多条数据之后都获取不到数据,table的id我也检查过了没问题。 前端控制台输出是这样的: ``` Object data: Array(0) length: 0 __proto__: Array(0) isAll: false __proto__: Object ``` 但是我又试了全选,神奇的发现全选能选择,有没有大佬能帮忙解释下这是什么问题啊,怎么才能解决
layui table获取数据,done未执行,数据未获取
![图片说明](https://img-ask.csdn.net/upload/201907/15/1563174491_975204.png) ![图片说明](https://img-ask.csdn.net/upload/201907/15/1563174503_373499.png)![图片说明](https://img-ask.csdn.net/upload/201907/15/1563174508_342653.png)![图片说明](https://img-ask.csdn.net/upload/201907/15/1563174515_724239.png) done方法不执行,json数据和Html通过sublime部署在本地,也没有显示报错,状态码显示200,但是就是不显示数据,请大神指点
jsp页面的$.ajax在网站上无法执行,在eclipse中运行正常
jsp页面的$.ajax在网站上无法执行,在eclipse中运行正常,浏览器显示“Can't find variable: $ 以下是JSP中的fuction中的代码 $.ajax({ type : "post", async : false, //同步执行 url : "bar.do", data : para, dataType : "json", success : function(result) { if (result) {
iframe框架里的layui弹出层 怎么在父页面显示?
父页面: ``` <div class="disease-box"> <iframe src="page/disease.aspx" id="iframe3" frameborder="0" width="100%" height="100%"></iframe> </div> ``` iframe: ``` <div class="condition-btn-box"> <a href="javascript:void(0)" class="search-btn" onclick="butnSel()">查询</a> </div> <table class="layui-hide" id="demo" lay-filter="test"></table> <div class="disease-detail-box"></div> //disease-detail-box内容后台拼出来的 <script type="text/javascript"> $(function () { butnSel(); }); function butnSel() { layui.use('table', function () { var table = layui.table; table.render({ elem: '#demo' , method: 'post' , url: "../Hand/HandlerAdmin.ashx/searchDiseaseData" , where: {} , page: true //开启分页 , cols: [[ { field: 'R', title: '序号', width: 80, align: 'center', sort: true } ]] }); //监听行单击事件(双击事件为:rowDouble) table.on('rowDouble(test)', function (obj) { var data = obj.data; $.ajax({ type: "post", data: { "id": data.ID }, url: "../Hand/HandlerAdmin.ashx/DiseaseInfo", success: function (data) { $(".disease-detail-box").html(data); layer.open({ type: 1, title: '病害详情', area: ['1000px', '500px'], moveOut:true, content: $('.disease-detail-box') }); } }); }); }) } </script> ``` 代码差不多是这样。 问题是双击事件弹出的div(disease-detail-box)怎么显示在父页面显示?
请问使用SSH框架结合ajax后,怎么实现查询功能?
请问使用SSH框架结合ajax后,怎么实现查询功能?就是,把查询条件用jquery ajax提交, 然后加载table;我现在是能提交,但不知道怎么返回list加载到table中?谢谢!
html5前端ajax代码不执行,求解决
对第一个ajax后的返回结果进行判断.成功则进行第二个Ajax.之后在重新刷新页面. 目前的问题是.第一个ajax返回的结果为成功.但是第二个ajax不会执行. 在第二个ajax后添加alert(); 就可以正常执行ajax . 使用了setTimeout 但是还是存在问题.
大神们求帮助!layui行内工具栏怎么做判断
![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267680_397076.png) ``` <!--行内工具栏--> <script type="text/html" id="barDemo"> <a class="layui-btn layui-btn-radius layui-btn-xs" lay-event="fahuo" >发货</a> <a class="layui-btn layui-btn-radius layui-btn-xs" lay-event="particulars" >详情</a> </script> ``` ![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267715_449356.png) ``` <script> layui.use([ 'table', 'form', 'layer' ], function() { var table = layui.table; var form = layui.form; var layer = layui.layer; //var $ = layui.$;//用不到jq table.render({ elem : '#demo', //height: 432,//都不分页了也不设置高度了,自适应有多少显示多少 url : 'adminSelectOrder', method : 'post', //where: {//不需要token,也就不需要条件 // 'token': globalData.myToken //}, title : '订单表', toolbar : '#topToolbar', page : true, // 等等... ``` ![图片说明](https://img-ask.csdn.net/upload/201912/25/1577267776_835625.png) 我想根据订单状态来显示这个发货按钮,比如:订单为待发货时才显示发货这个按钮,大神们怎么判断,教一下,受小弟一拜!!! 谢谢啦
多个AJAX的执行问题,执行顺序,逻辑执行
多个AJAX怎么让他们有先后的执行顺序,甚至有逻辑的执行。需要用到什么技术
spring+ajax回调函数如何保证同步执行
js中调用了ajax方法,我需要ajax中的回调函数执行完成之后在执行js的下一行。请问如何能保证该同步功能。
在网速差连续执行ajax 请求,回调函数不执行
在网速差连续执行ajax 请求,回调函数不执行,还是说innerHTML函数连续执行不出错。
JavaScript 的一个方法里面包含ajax方法下面的方法不会执行吗
JavaScript 的一个方法里面包含ajax方法和一个普通方法,但是普通方法放在ajax下面,却 不执行了,为什么? ![图片说明](https://img-ask.csdn.net/upload/201704/26/1493188571_863062.png)
js加入ajax,怎么运行不了了
以前是学习后台的。刚刚接触ajax,很多问题还不懂,结果代码运行不了,急死了,超级打击积极心。 ajax需要引包吗,但是仅仅是下面的两行代码。。。 为什么运行不了?虚心求教 ``` var inputElement = document.getElementById("tid"); alert(inputElement.value); ```
JS函数里面的$.ajax无法执行是怎么回事
在一个函数里使用$.ajax,结果不执行,应该是报错了,因为alert的测试是进去到了这个js函数,而进去了就完了。。。函数结束后的alert(结束了)并没有执行, 这是怎么回事啊?临时要用前端,查资料写的,也不知道哪儿出了问题,照着别人的复制的,数据是自己写的 **这是调用的js函数** ``` function changeDate(zoneId) { alert("进来了"); var para="zoneId="+zoneId; $.ajax({ url:"demo/demo?zoneId="+zoneId, type:"get", dataType:"json", success:function(data) { alert("成功"); } }); } ``` **这是在函数里调用该函数,先alert(开始了),再调用函数,调用完再alert(结束了)** ``` alert("开始了"); changeDate("1"); alert("结束了?"); ```
这个js是不是有语法错误?循环里面的东西在运行的时候没有执行,求大佬指点。
如题, 我想在一个Chart里面画出三个波形图,就将三个波形的数据都放在一个数组myDatasets里面。然后再赋值给Chart,但运行的时候发现整个循环里面所有的东西都没运行,包括 ``` console.log ``` 也没运行,但控制台又没报错,实在一头雾水,是不是我语法哪里有问题?求大佬帮帮忙QAQ 这是我整个函数↓ ``` function drawWaveform(datas){ console.log("绘制开始。。。"); var lineChart = $("#waveform"); console.log(datas); var xs=[]; var allYs=[]; var myDatasets=[]; var ys=[]; var k=0; for(;k<datas.length;k++){ //【从这里开始就没运行了】 console.log(k); var points=datas[k].points; console.log(points); for(var i = 0;i<points.length;i++){ if(i==0){ xs.push(points[i].x); } ys.push(points[i].y); } allYs.push(ys); var color=""; if(datas[k].phrase=="A"){ color="#FFD700";//gold(yellow) var curDataset={ label: datas[k].phrase, fill: false, lineTension: 0.1, backgroundColor: "#fff", borderColor: color, borderCapStyle: 'butt', borderDash: [], borderDashOffset: 0.0, borderJoinStyle: 'miter', pointBorderColor: "#fff",//white pointBackgroundColor: "#141E41",//black pointBorderWidth: 1, pointHoverRadius: 10, pointHoverBackgroundColor: "#FC2055",//red pointHoverBorderColor: "#fff", pointHoverBorderWidth: 1, pointRadius: 0, pointHitRadius: 10, data: ys, spanGaps: false }; this.myDatasets.push(curDataset); } if(datas[k].phrase=="B"){ color="#047bf8";//blue var curDataset={ label: datas[k].phrase, fill: false, lineTension: 0.1, backgroundColor: "#fff", borderColor: color, borderCapStyle: 'butt', borderDash: [], borderDashOffset: 0.0, borderJoinStyle: 'miter', pointBorderColor: "#fff",//white pointBackgroundColor: "#141E41",//black pointBorderWidth: 1, pointHoverRadius: 10, pointHoverBackgroundColor: "#FC2055",//red pointHoverBorderColor: "#fff", pointHoverBorderWidth: 1, pointRadius: 0, pointHitRadius: 10, data: ys, spanGaps: false }; this.myDatasets.push(curDataset); } if(datas[k].phrase=="C"){ color="#FC2055";//red var curDataset={ label: datas[k].phrase, fill: false, lineTension: 0.1, backgroundColor: "#fff", borderColor: color, borderCapStyle: 'butt', borderDash: [], borderDashOffset: 0.0, borderJoinStyle: 'miter', pointBorderColor: "#fff",//white pointBackgroundColor: "#141E41",//black pointBorderWidth: 1, pointHoverRadius: 10, pointHoverBackgroundColor: "#FC2055",//red pointHoverBorderColor: "#fff", pointHoverBorderWidth: 1, pointRadius: 0, pointHitRadius: 10, data: ys, spanGaps: false }; this.myDatasets.push(curDataset); } ys=[]; //【到这里结束】 } //【这里开始有结果】 console.log(myDatasets); // line chart data var lineData = { labels: xs, datasets: myDatasets }; // line chart init var myLineChart = new Chart(lineChart, { type: 'line', data: lineData, options: { legend: { display: false }, scales: { xAxes: [{ ticks: { fontSize: '11', fontColor: '#969da5' }, gridLines: { color: 'rgba(0,0,0,0.05)', zeroLineColor: 'rgba(0,0,0,0.05)' } }], yAxes: [{ display: false, ticks: { beginAtZero: true, max: 65 } }] } } }); console.log("绘制结束"); } ``` 在这个函数的ajax里面调用的这个函数↓ ``` function show3(id1,id2,id3) { console.log("show3"); var ids=[id1,id2,id3]; var flag = false; //标识,表示页面上数据还未处理完成 var datas=[]; console.log(ids); for(var i=0;i<3;i++){ //console.log(ids); var curid=ids[i]; $.ajax({ type : "get", url : "observe/getImage", data : { ID : curid }, beforeSend: function () { ShowDiv(); }, complete: function () { HiddenDiv(); }, success : function(data) { console.log(data) datas.push(data); } }); } console.log(datas); //绘制波形图 //drawWaveform(data.points); drawWaveform(datas);//【**在这里调用的**】 $("#closeDivBtn").html("<input class=\"mr-2 mb-2 btn btn-primary btn-lg\" type=\"button\" value=\"关闭\" onclick=\"CloseDiv('MyDiv','fade')\">"); AlertDiv('MyDiv','fade'); } ```
layui的弹出层中我加了一个日期选择器,但是不好使,一闪而过 添加了trigger: 'click',也不行
<!DOCTYPE html> <html> <head> <link rel="stylesheet" href="layui/css/layui.css" media="all"> </head> <body> <a class="layui-btn" id="test" href="javascript:;">添加员工</a><br /><br /> <div class="layui-form"> <div class="layui-form-item"> <div class="layui-inline"> <label class="layui-form-label">中文版</label> <div class="layui-input-inline"> <input class="layui-input" id="test1" type="text" placeholder="yyyy-MM-dd"> </div> </div> </div> </div> <div class="layui-row" id="popSearchRoleTest" style="display:none;"> <div class="layui-col-md11"> <form class="layui-form" lay-filter="formTestFilter"> <div class="layui-form-item"> <label class="layui-form-label">员工姓名:</label> <div class="layui-input-inline"> <input type="text" name="empName" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">员工性别:</label> <div class="layui-input-block"> <input type="radio" name="sex" value="男" title="男"> <input type="radio" name="sex" value="女" title="女" checked> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">员工年龄</label> <div class="layui-input-inline"> <select name="city" lay-verify="required"> <option value="0">请选择</option> <option value="1">18</option> <option value="2">19</option> <option value="3">20</option> <option value="4">21</option> <option value="5">22</option> </select> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">出生日期:</label> <div class="layui-input-inline"> <input type="datetime" name="empbirthday" class="layui-input" οnclick="return false;"> </div> </div> <div class="layui-form-item"> <div class="layui-inline"> <label class="layui-form-label">出生日期</label> <div class="layui-input-inline"> <input class="layui-input" id="time" name="time" type="text" placeholder="yyyy-MM-dd"> </div> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">员工职位</label> <div class="layui-input-inline"> <select name="city" lay-verify="required"> <option value="0">请选择</option> <option value="1">董事</option> <option value="2">经理</option> <option value="3">店长</option> <option value="4">发型师</option> <option value="5">助理</option> </select> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">联系方式:</label> <div class="layui-input-inline"> <input type="text" name="empPhone" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">入职时间:</label> <div class="layui-input-inline"> <input type="text" name="empEntryTime" class="layui-input"> </div> </div> <div class="layui-form-item"> <div class="layui-input-block"> <button class="layui-btn" lay-submit lay-filter="formDemo">立即提交</button> <button type="reset" class="layui-btn layui-btn-primary">重置</button> </div> </div> </form> </div> </div> <script src="layui/layui.js"></script> <script src="layui/layui.all.js" type="text/javascript" charset="utf-8"></script> <script type="text/javascript"> layui.use(["jquery", "layer", "form", "laydate"], function() { var $ = layui.$, layer = layui.layer, form = layui.form, laydate = layui.laydate; //监听提交 form.on('submit(popSearchRoleTest)', function(data) { layer.msg(JSON.stringify(data.field)); return false; }); $("#test").click(function() { hello(); }); window.hello = function() { layer.open({ //layer提供了5种层类型。可传入的值有:0(信息框,默认)1(页面层)2(iframe层)3(加载层)4(tips层) type: 1, title: "查找用户角色", area: ['100%', '100%'], content: $("#popSearchRoleTest").html(), success: function() { $(this).removeAttr("lay-key"); laydate.render({ elem: '#time', type: 'date', trigger: 'click', }); form.render(); }, }); } form.on('submit(formDemo)', function(data) { /* window.console.log(data.field); */ $.ajax({ type: "post", url: "http://localhost:8080/jiangdao/emp.action?methodName=addEmp", data: data.field, dataType: "json", success: (responseText) => { window.console.log("连接成功了" + responseText); }, error: () => { alert("服务器大大病了") } }); return false; }); }); </script> </body> </html>
火狐浏览器。$.ajax没运行完的时候切换页面,进入error
``` $.ajax({ type: 'post', data: data, url: 'Balance.aspx', cache: false, success: function (data) { getTable(data); }, error: function (err) { alert('cuole'); } }) ``` 火狐浏览器中,页面A进入的时候是通过ajax去后台取数据更新局部的。数据量比较大,在没更新完成前,点了页面B,会进入error。 chrome中不会出现这样的情况。 这个我问题我看到的比较表面。看似危险也不大。 我想多了解一点吧。为啥。
ajax调用wcf后返回的结果.ajax里面运行error错。
ajax调用wcf后返回的结果为list<entity>,这个list<entity>中又有一个list<entity1>.ajax里面运行error错。 [WebInvoke(RequestFormat = WebMessageFormat.Json, ResponseFormat = WebMessageFormat.Json)] 配置没有问题,因为把list<entity1>=null;就能够正常运行。
页面销毁后,ajax异步请求后台还执行吗
有一个ajax请求,在后台需要执行几分钟的时间,在这个过程中(success执行之前), 页面销毁掉,后台请求还在执行吗?
相见恨晚的超实用网站
搞学习 知乎:www.zhihu.com 简答题:http://www.jiandati.com/ 网易公开课:https://open.163.com/ted/ 网易云课堂:https://study.163.com/ 中国大学MOOC:www.icourse163.org 网易云课堂:study.163.com 哔哩哔哩弹幕网:www.bilibili.com 我要自学网:www.51zxw
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
字节跳动视频编解码面经
引言 本文主要是记录一下面试字节跳动的经历。 三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时
开源一个功能完整的SpringBoot项目框架
福利来了,给大家带来一个福利。 最近想了解一下有关Spring Boot的开源项目,看了很多开源的框架,大多是一些demo或者是一个未成形的项目,基本功能都不完整,尤其是用户权限和菜单方面几乎没有完整的。 想到我之前做的框架,里面通用模块有:用户模块,权限模块,菜单模块,功能模块也齐全了,每一个功能都是完整的。 打算把这个框架分享出来,供大家使用和学习。 为什么用框架? 框架可以学习整体
源码阅读(19):Java中主要的Map结构——HashMap容器(下1)
(接上文《源码阅读(18):Java中主要的Map结构——HashMap容器(中)》) 3.4.4、HashMap添加K-V键值对(红黑树方式) 上文我们介绍了在HashMap中table数组的某个索引位上,基于单向链表添加新的K-V键值对对象(HashMap.Node&lt;K, V&gt;类的实例),但是我们同时知道在某些的场景下,HashMap中table数据的某个索引位上,数据是按照红黑树
c++制作的植物大战僵尸,开源,一代二代结合游戏
    此游戏全部由本人自己制作完成。游戏大部分的素材来源于原版游戏素材,少部分搜集于网络,以及自己制作。 此游戏为同人游戏而且仅供学习交流使用,任何人未经授权,不得对本游戏进行更改、盗用等,否则后果自负。 目前有六种僵尸和六种植物,植物和僵尸的动画都是本人做的。qq:2117610943 开源代码下载 提取码:3vzm 点击下载--&gt; 11月28日 新增四种植物 统一植物画风,全部修
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成喔~) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 顺便拉下票,我在参加csdn博客之星竞选,欢迎投票支持,每个QQ或者微信每天都可以投5票,扫二维码即可,http://m234140.nofollow.ax.
Python 基础(一):入门必备知识
目录1 标识符2 关键字3 引号4 编码5 输入输出6 缩进7 多行8 注释9 数据类型10 运算符10.1 常用运算符10.2 运算符优先级 1 标识符 标识符是编程时使用的名字,用于给变量、函数、语句块等命名,Python 中标识符由字母、数字、下划线组成,不能以数字开头,区分大小写。 以下划线开头的标识符有特殊含义,单下划线开头的标识符,如:_xxx ,表示不能直接访问的类属性,需通过类提供
深度学习图像算法在内容安全领域的应用
互联网给人们生活带来便利的同时也隐含了大量不良信息,防范互联网平台有害内容传播引起了多方面的高度关注。本次演讲从技术层面分享网易易盾在内容安全领域的算法实践经验,包括深度学习图
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 欢迎 改进 留言。 演示地点跳到演示地点 html代码如下`&lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head&gt; &lt;title&gt;music&lt;/title&gt; &lt;meta charset="utf-8"&gt
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。 1. for - else 什么?不是 if 和 else 才
数据库优化 - SQL优化
前面一篇文章从实例的角度进行数据库优化,通过配置一些参数让数据库性能达到最优。但是一些“不好”的SQL也会导致数据库查询变慢,影响业务流程。本文从SQL角度进行数据库优化,提升SQL运行效率。 判断问题SQL 判断SQL是否有问题时可以通过两个表象进行判断: 系统级别表象 CPU消耗严重 IO等待严重 页面响应时间过长
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 c/c++ 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7
通俗易懂地给女朋友讲:线程池的内部原理
餐厅的约会 餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”我楞了一下,心里想女朋友今天是怎么了,怎么突然问出这么专业的问题,但做为一个专业人士在女朋友面前也不能露怯啊,想了一下便说:“我先给你讲讲我前同事老王的故事吧!” 大龄程序员老王 老王是一个已经北漂十多年的程序员,岁数大了,加班加不动了,升迁也无望,于是拿着手里
经典算法(5)杨辉三角
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 目录一、杨辉三角的介绍二、杨辉三角的算法思想三、代码实现1.第一种写法2.第二种写法 一、杨辉三角的介绍 百度
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹
面试官:你连RESTful都不知道我怎么敢要你?
面试官:了解RESTful吗? 我:听说过。 面试官:那什么是RESTful? 我:就是用起来很规范,挺好的 面试官:是RESTful挺好的,还是自我感觉挺好的 我:都挺好的。 面试官:… 把门关上。 我:… 要干嘛?先关上再说。 面试官:我说出去把门关上。 我:what ?,夺门而去 文章目录01 前言02 RESTful的来源03 RESTful6大原则1. C-S架构2. 无状态3.统一的接
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程实用技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法,并会持续更新。
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,
程序员:我终于知道post和get的区别
IT界知名的程序员曾说:对于那些月薪三万以下,自称IT工程师的码农们,其实我们从来没有把他们归为我们IT工程师的队伍。他们虽然总是以IT工程师自居,但只是他们一厢情愿罢了。 此话一出,不知激起了多少(码农)程序员的愤怒,却又无可奈何,于是码农问程序员。 码农:你知道get和post请求到底有什么区别? 程序员:你看这篇就知道了。 码农:你月薪三万了? 程序员:嗯。 码农:你是怎么做到的? 程序员:
"狗屁不通文章生成器"登顶GitHub热榜,分分钟写出万字形式主义大作
前言 GitHub 被誉为全球最大的同性交友网站,……,陪伴我们已经走过 10+ 年时间,它托管了大量的软件代码,同时也承载了程序员无尽的欢乐。 上周给大家分享了一篇10个让你笑的合不拢嘴的Github项目,而且还拿了7万+个Star哦,有兴趣的朋友,可以看看, 印象最深刻的是 “ 呼吸不止,码字不停 ”: 老实交代,你是不是经常准备写个技术博客,打开word后瞬间灵感便秘,码不出字? 有什么
推荐几款比较实用的工具,网站
1.盘百度PanDownload 这个云盘工具是免费的,可以进行资源搜索,提速(偶尔会抽风????) 不要去某站买付费的???? PanDownload下载地址 2.BeJSON 这是一款拥有各种在线工具的网站,推荐它的主要原因是网站简洁,功能齐全,广告相比其他广告好太多了 bejson网站 3.二维码美化 这个网站的二维码美化很好看,网站界面也很...
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU
相关热词 c# 输入ip c# 乱码 报表 c#选择结构应用基本算法 c# 收到udp包后回包 c#oracle 头文件 c# 序列化对象 自定义 c# tcp 心跳 c# ice连接服务端 c# md5 解密 c# 文字导航控件
立即提问