easyui datagrid 编辑行后如何保存

       $(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选中的不是“请选择”

6个回答

getEditors获取所有编辑器数组,调用getValue得到值如果是0就提示要选择

 { text: '保存', iconCls: 'icon-save', handler: function () {
                 var ets = $('#dd').datagrid('getEditors');
                 //注意编辑器所在下标
                 if ($(ets[1].target).combobox('getValue').toString() == '0') { alert('请选择性别!');return}
                 datagrid.datagrid("endEdit", editRow);
             }

保存时用ajax发送请求发送数据到你的动态页就好了,jquery会自动降rowData转为键值对字符串,服务器端request对象获取即可


            onAfterEdit: function (rowIndex, rowData, changes) {
                console.info(rowData);
                $.ajax({
                    url: 'xxxxxx', data: rowData, type: 'POST', complete: function (xhr) {
                        alert(xhr.responseText)
                    }
                });
                editRow = undefined;
            },
showbo
支付宝加好友偷能量挖 回复snaif_lx: 你不是console.info(rowData);输出数据了?f12调出开发工具,在控制台就可以看到了。或者使用alert(JSON.stringify(rowData))也行,但是注意JSON需要IE8+以上才支持或者使用非IE核心浏览器,如chrome
4 年多之前 回复
snaif_lx
snaif_lx 版主,我想alert出rowData各个字段的内容看下输入值的情况怎么操作呢?
4 年多之前 回复

给这个事件实现一个监听器就可以了。

 onAfterEdit    
                rowIndex, rowData, changes  当用户编辑完成时触发,参数如下:
rowIndex:正在编辑的行索引,从0开始。
rowData:对应于正在编辑的行的记录。
changes:被改变的字段内容,对应方式为字段:值。

添加一个监听器监听一下 当编辑完成时触发该操作

确实在onAfterEdit里面做,在这里面拿到数据然后ajax提交到后台保存。

combobox的值通过editor对象的getValue来获取,注意要指定列

onAfterEdit事件,做post提交 // return;
$("#fm").form("submit",{
url:that.saddOrUpadteUlr,
onSubmit:function(){
var isValid = $(this).form('validate');
if (!isValid){
$.messager.progress('close'); // 如果表单是无效的则隐藏进度条
}
return isValid; // 返回false终止表单提交

            },
            success:function(result){
                $.messager.progress('close');   // 如果提交成功则隐藏进度条
                result = $.parseJSON(result);
                if(result.success){
                    $.messager.alert("系统提示",result.message);
                    $("#dlg").dialog("close");
                    that.frestSearchForm();//重置搜索数据
                    //userManager.finitQuerybaseParams();
                     //带公司条件
                     that.squerybaseParams="companyId="+that.companyId;
                    that.fqueryData();
                } else{
                    $.messager.alert("系统提示","<font color='red'>"+result.message+"</font>");
                }
            }
        });
    }

    combobox可以通过api getValue获取
snaif_lx
snaif_lx 没有form怎么来的submit
4 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
easyui datagrid getChecked无法获取勾选的数据
easyui datagrid在编辑状态下,用鼠标勾选了数据行后,在调用acceptChanges接受数据更改,恢复到不可编辑状态时,此时调用getChecked无法获取到之前在编辑状态下勾选的数据,虽然此时数据行前面的复选框checkbox还是在勾选的状态。 easyui版本1.4.3
easyUI datagrid 列编辑
datagrid行上多个字段都是可编辑的,都有editor 属性,但是现在想要单击或双击某一列,打开当前列的编辑状态,求助大神,谢谢 答案找到了,谢谢 <script type="text/javascript"> $.extend($.fn.datagrid.methods, { editCell : function(jq, param) { return jq.each(function() { var opts = $(this).datagrid('options'); var fields = $(this).datagrid('getColumnFields', true).concat( $(this).datagrid('getColumnFields')); for ( var i = 0; i < fields.length; i++) { var col = $(this).datagrid('getColumnOption', fields[i]); col.editor1 = col.editor; if (fields[i] != param.field) { col.editor = null; } } $(this).datagrid('beginEdit', param.index); for ( var i = 0; i < fields.length; i++) { var col = $(this).datagrid('getColumnOption', fields[i]); col.editor = col.editor1; } }); } }); var editIndex = undefined; //结束编辑 function endEditing() { if (editIndex == undefined) { return true } if ($('#dg').datagrid('validateRow', editIndex)) { $('#dg').datagrid('endEdit', editIndex); editIndex = undefined; return true; } else { return false; } } //单击单元格 function onClickCell(index, field) { if (endEditing()) { $('#dg').datagrid('selectRow', index).datagrid('editCell', { index : index, field : field }); editIndex = index; } } </script>
easyui如何在datagrid的行编辑或新增的时候锁定行
**easyui如何在datagrid的行编辑或新增的时候锁定行, 让鼠标点击其他行后还是选中的当前编辑行?** 因为我发现如果在编辑行或新增行的时候,我把鼠标单击到其他行, 在获取数据的时候就获取不到编辑或新增的内容。
easyui datagrid search
easyui datagrid 我想要在行内编辑里面添加一个search框,请问怎么做???
easyui 嵌套datagrid 二级datagrid编辑问题
![图片说明](https://img-ask.csdn.net/upload/201612/05/1480923849_204859.png) 一级datagrid编辑没有问题 二级datagrid编辑时只有第一行可以编辑,其他行都报错
easyui datagrid中combobox的问题
如下图: ![图片说明](https://img-ask.csdn.net/upload/201506/27/1435398138_950017.png) 这是后台编辑页面,作用为新闻的管理(新闻实体的字段“是否在前台显示”的值只有“是”和“否”)。 我想让“是否在首页显示”这一列下面都有一个combobox,默认值为数据库中真实的值。如果某条新闻的这个字段值为“是”,则对应的combobox还有一个值为“否”的option,反之对应的combobox还有一个值为“是”的option。 从网上找了一段代码实现不了,请问该如何改呢?求大神帮忙! //实现新闻DataGird控件的绑定操作 function initTable(queryData) { $('#test').datagrid({ //定位到Table标签,Table标签的ID是test fitColumns: true, url: '/News/QueryAllNews', //指向后台的Action来获取当前用户的信息的Json格式的数据 title: '新闻公告', //标识 iconCls: 'icon-save', height: 368, nowrap: true, autoRowHeight: false, striped: true, collapsible: true, pagination: true, rownumbers: true, //sortName: 'ID', //根据某个字段给easyUI排序 sortOrder: 'asc', remoteSort: false, idField: 'NewsID', queryParams: queryData, //异步查询的参数 columns: [[ { field: 'ck', checkbox: true }, { title: '主键', field: 'NewsID', sortable: true, hidden: true, }, { title: '内容标题', field: 'NewsTitle', width: 50, sortable: true }, { title: '具体内容', field: 'NewsContent', sortable: true, hidden: true, }, { title: '创建时间', field: 'TimeStamp', sortable: true, }, { title: '所属类别', field: 'CategoryName', sortable: true, }, { title: '创建人', field: 'UserName', sortable: true }, { title: '是否在首页显示', field: 'IsEnable', align: 'center', editor: { type: 'combobox', options: { data: [{ value: '是', text: '是', 'selected': 'true' }, { value: '否', text: '否' }], panelHeight: 'auto' } }, sortable: true } ]], toolbar: [{ id: 'btnadd', text: '添加', iconCls: 'icon-add', handler: function () { //实现弹出注册信息的页面 AddNews(); } }, '-', { id: 'btncut', text: '修改', iconCls: 'icon-cut', handler: function () { //实现修改的方法 UpdateLzjs(); } }, '-', { id: 'btnCancle', text: '删除', iconCls: 'icon-remove', handler: function () { //实现直接删除所有数据的方法 DeleteLzjs(); } }] }); }
easyui datatrid如何给编辑过的数据行标记下
  easyui DataGrid,如果数据行编辑过或者进入过编辑模式,当切换到显示模式,非编辑模式下,如何高亮之前的数据行?效果如下 ![](http://www.w3dev.cn/imgblog/20170911/0934301269.png)
easyui datagrid 中combobox显示问题
我的列表中有个下拉框当选择一项后页面上所显示的是代码而不是文字,我的下拉框代码如下:function addEditorPosition(){ ``` $("#borrow_detailinfo").datagrid('addEditor',{ field:'borrow_type',title:'借款类型',width:150,align:'center', formatter: unitformatter, editor:{ type:'combobox', //设置下拉框 options:{ //url:cusUrl, //ajax请求配置下拉框选项 data:positions, valueField : 'enname', //存储字段码 textField : 'cnname', //显示字段值 required : true, editable : false, onSelect:function(record){ //选择后结束行编辑 } } } }); } ``` 匹配的方法代码如下: ``` function unitformatter(value) { for (var i = 0; i < positions.length; i++) { if (positions[i].enname == value) { alert(value); return positions[i].enname; } } return value; } ``` 这个方法干脆就不走,求大神,求帮助。
easyui中datagrid合并单元格后,再编辑。单元格错位怎么解决?
easyui中datagrid合并单元格后,当开启其他列某一个单元格进入编辑状态时,合并行会出现错位,该怎么解决啊???
动态生成的easyui datagrid怎么获得改变的值????
datagrid为动态生成的可编辑表格,用getchanges方法没有改变的值也会得到???
easyui中的datagrid表格中,如何提交所有的行数据到后台
如题,我在一个controller中查到一些数据,并将它们显示在前台,现在我需要将 这些数据编辑之后提交到后台并保存,如何将datagrid中的所有数据提交到后台
easyui怎么给datagrid行编辑模式的日期选择框添加onselect事件?
mydateEditor.target.datebox({ onSelect:function(){ } }); 这么写虽然不会报错,但datebox上的按钮不见了,不能选择日期了,只能输入日期。
easyui的datagrid的行如果嵌入百度的富文本编辑器
其中一个字段如hwb需要把它转为百度的富文本编辑器; 另外需要可以初始值,也可以提交值。
java中怎么实现easyUi行编辑保存后显示保存的信息
<script> $(function(){ $("#list_data").datagrid({ url: "${ctx}/ssgl/sspf/pagination", title: "宿舍评分", iconCls:"icon-edit", loadMsg: "数据加载中,请稍候...", nowrap: false, pageSize: 10, pageList: [5, 10, 15,20], fitColumns: true, singleSelect: true, pagination: true, rownumbers:true, frozenColumns:[[ {field:"action",title:"操作",width:70,align:"center", formatter:function(value,row,index){ if (row.editing){ var s = '<a href="#" onclick="saverow('+index+')">保存</a> '; return s; } else { var e = '<a href="#" onclick="editrow('+index+')">编辑</a> '; return e; } } }, {field:'LMC',title:'公寓楼',align:'center',width:120}, {field:'SSFJH',title:'宿舍房间号',align:'center',width:100,}, ]], onBeforeEdit:function(index,row){ row.editing = true; $('#list_data').datagrid('refreshRow', index); }, onAfterEdit:function(index,row,changes){ row.editing = false; var str = ""; for(var p in changes){ str = str+changes[p]+','; } var SSFJH = row.SSFJH; $.ajax({ type:"post", url:"${ctx}/ssgl/sspf/save", data:{ "SSFJH":SSFJH, "changes":str, }, dataType:"json", success:function(date){ if(date==1){ $.messager.alert('提示','保存成功'); }else{ $.messager.confirm("提示", "保存失败", function (r) { if (r) { window.location.reload(); } }) } } }); }, }); loadDatagrid(); }); //加载评分项列 function loadDatagrid() { var columns=new Array(); $.ajax({ url:"${ctx}/ssgl/sspf/pfx", type:"POST", success: function(data){ $.each(data,function(index,content){ var column={}; column["title"]=content.PFXMC; column["field"]='DF'+index; column["width"]=130; column["align"]='center'; column["editor"]='numberbox'; columns.push(column); }); $("#list_data").datagrid({ columns:[columns] }); } }); } //查询 function FindData(){ $("#list_data").datagrid("load",{ LH:$("#cc").val(), SSFJH:$("#ss").val(), }); } //编辑 function editrow(index){ $('#list_data').datagrid('beginEdit', index); } //保存 function saverow(index){ $('#list_data').datagrid('endEdit', index); } </script> body里的 <table id="list_data" class="easyui-datagrid" toolbar="#searchtool"> <thead> </thead> <tbody id="tb"> </tbody> </table> (加载评分项列这里的表格并不是在body里而是在 js里用each循环出来的,)
Easyui datagrid IE下 行编辑器中控件会随滚动条浮动
![图片说明](https://img-ask.csdn.net/upload/201501/14/1421230926_354276.png)
easyui datagrid combobox联动的问题
{ field: 'NMJ04', title: '夫妇姓名', width: 100, sortable: true, editor: {type: 'combobox', options: { required: true, url: '/handler/familyinfo.ashx?flag=treeClubNet&t=4', dataType: 'json', parentField: 'pid', textFiled: 'text', valueField: 'id', method: 'get', lines: true, editable: false, panelHeight: 130, onSelect: function (record) { var row = $('#dd').datagrid('getSelected'); var rowIndex = $('#dd').datagrid('getRowIndex',row);//获取行号 var target = $('#dd').datagrid('getEditor', {'index':rowIndex,'field':'NMJ05'});//.target; target.combobox('clear'); //清除原来的数据 var url = '/handler/spouseinfo.ashx?flag=getValueNMK06&t='+record.id; target.combobox('reload', url);//联动下拉列表重载 //这里还需要设置一个textbox的值,NMJ06,怎么办? }, panelMaxWidth: 200 } } }, NMJ04是姓名,选择了之后自动提出NMJ05(性别)和NMJ06,身份证号码 新增行和编辑行的时候怎么操作啊? 我新增时row的值直接是null,求教求教
easyui datagrid新增一行数据如何设置text框的属性
var colnum_staff = [[ {field:'before_iscore',title:'选择',checkbox:true}, {field:'borrow_id',title:'明细编号',width:200,align:'center', editor:{ type:'text', name:'addBorrowInfo.id' } }, {field:'borrow_name',title:'借款事项',width:200,align:'center', editor:{ type:'text', name:'borrowdetail' } }, {field:'borrowtype_code',title:'借款类型',width:200,align:'center', editor:{ type:'combobox', //设置下拉框 name:'addBorrowInfo.borrow_type', formatter:positionFormatter, options:{ data:positions, valueField : 'enname', //存储字段码 textField : 'cnname', //显示字段值 required : true, editable : false, onSelect:function(record){ //选择后结束行编辑 //updatePositionExist(record); } } } }, {field:'borrow_amound',title:'借款金额',width:200,align:'center', editor:{ type:'text' } } ]]; 这是colnum代码,我的意思是在这个field里怎么设置输入框的name属性,和onblur事件,求大神们指点。 点击新增按钮新增一行,如何设置这一行中的输入框的name属性,和onblur事件。求大神指点。
easyui datagrid,获取当前选中的列名
我有一个可以编辑的DataGrid, 我想得到我现在鼠标焦点所处的列名,field。 当还未处于编辑状态时,可以通过DataGrid的onClickCell事件来获取到field,在编辑状态的时候,怎么获取到field 就是希望在鼠标点击格子之后,可以获取到当前的光标所处格子的字段名,field
easyui datatrid如何给编辑过的数据行高亮描红
easyui DataGrid,如果数据行编辑过或者进入过编辑模式,当切换到显示模式,非编辑模式下,如何高亮之前的数据行?效果如下图所示 ![图片说明](https://img-ask.csdn.net/upload/201802/11/1518333879_587689.png)
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
相关热词 基于c#波形控件 c# 十进制转十六进制 对文件aes加密vc# c#读取栈中所有的值 c# rsa256加密 好 学c# 还是c++ c# 和java的差距 c# curl网络框架 c# https证书请求 c# 中崎
立即提问