标签定义的列的表。
使用JavaScript创建数据表格。
$('#dg').datagrid({
url:'datagrid_data.json',
columns:[[
{field:'code',title:'Code',width:100},
{field:'name',title:'Name',width:100},
{field:'price',title:'Price',width:100,align:'right'}
]]
});
查询数据填充数据表格。
$('#dg').datagrid('load', {
name: 'easyui',
address: 'ho'
});
数据更改与服务器交互,刷新当前数据。
$('#dg').datagrid('reload'); // reload the current page data
数据表格属性(DataGrid Properties)
属性继承控制面板,以下是数据表格独有的属性。
名称
类型
描述
默认值
columns
array
数据表格列配置对象,查看列属性以获取更多细节。
undefined
frozenColumns
array
跟列属性一样,但是这些列固定在左边,不会滚动。
undefined
fitColumns
boolean
设置为true将自动使列适应表格宽度以防止出现水平滚动。
false
autoRowHeight
boolean
定义设置行的高度,根据该行的内容。设置为false可以提高负载性能。
true
toolbar
array,selector
数据表格顶部面板的工具栏。可能的值: 1)数组,每个工具选项和链接按钮相同。 2)选择显示的工具栏。 在一个的标签定义工具栏:
$('#dg').datagrid({
toolbar: '#tb'
});
通过数组定义工具栏:
$('#dg').datagrid({
toolbar: [{
iconCls: 'icon-edit',
handler: function(){alert('edit')}
},'-',{
iconCls: 'icon-help',
handler: function(){alert('help')}
}]
});
null
striped
boolean
设置为true将交替显示行背景。
false
method
string
请求远程数据的方法类型。
post
nowrap
boolean
设置为true,当数据长度超出列宽时将会自动截取。
true
idField
string
表明该列是一个唯一列。
null
url
string
一个用以从远程站点请求数据的超链接地址。
null
loadMsg
string
当从远程站点载入数据时,显示的一条快捷信息。
Processing, please wait …
pagination
boolean
设置true将在数据表格底部显示分页工具栏。
false
rownumbers
boolean
设置为true将显示行数。
false
singleSelect
boolean
设置为true将只允许选择一行。
false
checkOnSelect
boolean
如果为true,该复选框被选中/取消选中,当用户点击某一行上。如果为false,该复选框仅检查/取消选中,当用户点击完全的复选框。 此属性是1.3版本。
true
selectOnCheck
boolean
如果设置为true,单击一个复选框,将始终选择行。如果为false,不会选择行选中该复选框。 此属性是1.3版本。
true
pagePosition
string
定义的分页栏的位置。可用的值有 'top','bottom','both'。 此属性是可自1.3版本。
bottom
pageNumber
number
当设置分页属性时,初始化分页码。
1
pageSize
number
当设置分页属性时,初始化每页记录数。
10
pageList
array
当设置分页属性时,初始化每页记录数列表。
[10,20,30,40,50]
queryParams
object
当请求远程数据时,发送的额外参数。 示例:
$('#dg').datagrid({
queryParams: {
name: 'easyui',
subject: 'datagrid'
}
});
{}
sortName
string
当数据表格初始化时以哪一列来排序。
null
sortOrder
string
定义排序顺序,可以是'asc'或者'desc'(正序或者倒序)。
asc
remoteSort
boolean
定义是否通过远程服务器对数据排序。
true
showFooter
boolean
定义是否显示行底(如果是做统计表格,这里可以显示总计等)。
false
rowStyler
function
返回样式,如:'background:red',function有2个参数: index:行索引,从0开始. row:对应于该行记录的对象。 示例:
$('#dg').datagrid({
rowStyler: function(index,row){
if (row.listprice>80){
return 'background-color:#6293BB;color:#fff;';
}
}
});
loader
function
定义如何从远程服务器加载数据。返回false可以取消该操作。这个函数接受以下参数: param: 参数对象传递到远程服务器。 success(data): 回调函数将被调用成功检索的数据。 error():回调函数将被调用失败时检索数据。
json loader
loadFilter
function
返回过滤的数据显示。该函数需要一个参数'data',表示原始数据。您可以更改源数据的标准数据格式。此函数必须返回标准数据对象中包含的“total”和“rows”的属性。 示例:
// removing 'd' object from asp.net web service json output
$('#dg').datagrid({
loadFilter: function(data){
if (data.d){
return data.d;
} else {
return data;
}
}
});
editors
object
定义当编辑一行时的编辑模式。
predefined editors
view
object
定义数据表格的视图。
default view
列属性(Column Properties)
数据表格的列是一个对象数组,即这个对象中的元素也是一个数组(js中数组是对象)。 对象数组中的每一个元素都是可配置的对象,每个可配置对象定义一个列。
示例:
columns:[[
{field:'itemid',title:'Item ID',rowspan:2,width:80,sortable:true},
{field:'productid',title:'Product ID',rowspan:2,width:80,sortable:true},
{title:'Item Details',colspan:4}
],[
{field:'listprice',title:'List Price',width:80,align:'right',sortable:true},
{field:'unitcost',title:'Unit Cost',width:80,align:'right',sortable:true},
{field:'attr1',title:'Attribute',width:100},
{field:'status',title:'Status',width:60}
]]
名称
类型
描述
默认值
title
string
列标题。
undefined
field
string
列字段。
undefined
width
number
列宽。
undefined
rowspan
number
表明一个单元格跨几行。
undefined
colspan
number
表明一个单元格跨几列。
undefined
align
string
表明如何对其列数据,可选值:'left','right','center'。
undefined
sortable
boolean
设置为true允许对该列排序。
undefined
resizable
boolean
设置为true允许该列被缩放。
undefined
hidden
boolean
设置为true将隐藏列。
undefined
checkbox
boolean
设置为true将显示复选框。
undefined
formatter
function
格式化单元格函数,有3个参数: value:字段的值。 rowData:行数据。 rowIndex:行索引。 示例:
$('#dg').datagrid({
columns:[[
{field:'userId',title:'User', width:80,
formatter: function(value,row,index){
if (row.user){
return row.user.name;
} else {
return value;
}
}
}
]]
});
undefined
styler
function
单元格样式函数,返回样式字符串装饰表格如'background:red',function有3个参数: value:字段值。 rowData:行数据。 rowIndex:行索引。 示例:
$('#dg').datagrid({
columns:[[
{field:'listprice',title:'List Price', width:80, align:'right',
styler: function(value,row,index){
if (value < 20){
return 'background-color:#ffee00;color:red;';
}
}
}
]]
});
undefined
sorter
function
T自定义字段排序函数,有2个参数: a:该列的第一个值。 b:该列的第二个值。 示例:
$('#dg').datagrid({
remoteSort: false,
columns: [[
{field:'date',title:'Date',width:80,sortable:true,align:'center',
sorter:function(a,b){
a = a.split('/');
b = b.split('/');
if (a[2] == b[2]){
if (a[0] == b[0]){
return (a[1]>b[1]?1:-1);
} else {
return (a[0]>b[0]?1:-1);
}
} else {
return (a[2]>b[2]?1:-1);
}
}
}
]]
});
undefined
editor
string,object
表明编辑类型。如果属性是字符串类型表示编辑类型,如果是对象则包含2个参数: type:字符串,编辑类型,可选值:text,textarea,checkbox,numberbox,validatebox,datebox,combobox,combotree。 options:对象,对象于编辑类型的编辑器属性。
undefined
编辑器(Editor)
使用$.fn.datagrid.defaults.editors重载默认值。
每个编辑器都有以下方法:
名称
属性
描述
init
container, options
初始化编辑器并返回目标对象。
destroy
target
注销编辑器。
getValue
target
获取编辑框的值。
setValue
target , value
设置编辑框的值。
resize
target , width
调整编辑器
如下代码将定义一个文本编辑器:
$.extend($.fn.datagrid.defaults.editors, {
text: {
init: function(container, options){
var input = $(' ').appendTo(container);
return input;
},
getValue: function(target){
return $(target).val();
},
setValue: function(target, value){
$(target).val(value);
},
resize: function(target, width){
var input = $(target);
if ($.boxModel == true){
input.width(width - (input.outerWidth() - input.width()));
} else {
input.width(width);
}
}
}
});
数据表格视图(DataGrid View)
使用$.fn.datagrid.defaults.view重载默认值。
视图是一个告诉数据表格如何呈现行记录的对象,对象必须定义以下方法:
名称
属性
描述
render
target, container, frozen
当数据载入时调用。 target: DOM对象,数据网格对象。 container: 行记录容器。 frozen: 是否呈现固定容器。
renderFooter
target, container, frozen
这是一个可选函数用以展现行底。
renderRow
target, fields, frozen, rowIndex, rowData
这是一个可选函数,它可以被render函数调用。
refreshRow
target, rowIndex
定义如何刷新指定的行。
onBeforeRender
target, rows
在视图被呈现之前触发。
onAfterRender
target
在视图被程序之后触发。
事件(Events)
事件继承控制面板,以下是数据表格独有的属性。
名称
属性
描述
onLoadSuccess
data
当数据载入成功时触发。
onLoadError
none
当载入远程数据发生错误时触发。
onBeforeLoad
param
在请求载入数据之前触发,如果返回false将取消载入。
onClickRow
rowIndex, rowData
当用户点击行时触发,参数如下: rowIndex:被点击的行索引,从0开始。 rowData:对应于被点击的行的记录。
onDblClickRow
rowIndex, rowData
当用户双击一行时触发,参数如下: rowIndex:被点击的行索引,从0开始。 rowData:对应于被点击的行的记录。
onClickCell
rowIndex, field, value
当用户点击单元格时触发。
onDblClickCell
rowIndex, field, value
当用户双击单元格时触发。 示例:
// when double click a cell, begin editing and make the editor get focus
$('#dg').datagrid({
onDblClickCell: function(index,field,value){
$(this).datagrid('beginEdit', index);
var ed = $(this).datagrid('getEditor', {index:index,field:field});
$(ed.target).focus();
}
});
onSortColumn
sort, order
当用户对列排序时触发,参数如下: sort:排序字段名称。 order:排序顺序。
onResizeColumn
field, width
当用户调整列宽时触发。
onSelect
rowIndex, rowData
当用户选择一行是触发,参数如下: rowIndex:被选择的行索引,从0开始。 rowData:对应于被选择行的记录。
onUnselect
rowIndex, rowData
当用户取消选择一行时触发,参数如下: rowIndex:被取消选择的行索引,从0开始。 rowData:对应于被取消选择行的记录。
onSelectAll
rows
当用户选择所有行时触发。
onUnselectAll
rows
当用户取消选择所有行时触发。
onCheck
rowIndex,rowData
当用户选中行时触发,参数包含: rowIndex:选中行的索引,从0开始 rowData:选中的行对应的记录 此属性是1.3版本。
onUncheck
rowIndex,rowData
当用户取消选中行时触发,参数包含: rowIndex:取消选中行的索引,从0开始 rowData:未经检查的行对应的记录 此属性是1.3版本。
onCheckAll
rows
当用户检查所有行时触发。此属性是1.3版本。
onUncheckAll
rows
用户取消所有行时触发。此属性是1.3版本。
onBeforeEdit
rowIndex, rowData
当用户开始编辑一行时触发,参数如下: rowIndex:正在编辑的行索引,从0开始。 rowData:对应于正在编辑的行的记录。
onAfterEdit
rowIndex, rowData, changes
当用户编辑完成时触发,参数如下: rowIndex:正在编辑的行索引,从0开始。 rowData:对应于正在编辑的行的记录。 changes:被改变的字段内容,对应方式为字段:值。
onCancelEdit
rowIndex, rowData
当用户取消编辑行时触发,参数如下: rowIndex:正在编辑的行索引,从0开始。 rowData:对应于正在编辑的行的记录。
onHeaderContextMenu
e, field
当数据表格的列标题被鼠标右键单击时触发。
onRowContextMenu
e, rowIndex, rowData
当一行被鼠标右键单击时触发。
方法(Methods)
名称
属性
描述
options
none
返回属性对象。
getPager
none
返回页面对象。
getPanel
none
返回控制面板对象。
getColumnFields
frozen
返回列字段,如果设置了frozen属性为true,将返回固定列的字段名。 示例: var opts = $('#dg').datagrid('getColumnFields'); // get unfrozen columns
var opts = $('#dg').datagrid('getColumnFields', true); // get frozen columns
getColumnOption
field
返回特定的列属性。
resize
param
缩放和布局。
load
param
载入并显示第一页的记录,如果传递了'param'参数,它将会覆盖查询参数属性的值。通过传递一些参数,通常做一个查询,这个方法可以被称为从服务器加载新数据。 $('#dg').datagrid('load',{
code: '01',
name: 'name01'
});
reload
param
重载记录,跟'load'方法一样但是重载的是当前页的记录而非第一页。
reloadFooter
footer
重载行底记录。 示例: // update footer row values and then refresh
var rows = $('#dg').datagrid('getFooterRows');
rows[0]['name'] = 'new name';
rows[0]['salary'] = 60000;
$('#dg').datagrid('reloadFooter');
// update footer rows with new data
$('#dg').datagrid('reloadFooter',[
{name: 'name1', salary: 60000},
{name: 'name2', salary: 65000}
]);
loading
none
显示载入状态。
loaded
none
隐藏载入状态。
fitColumns
none
让列宽自动适应数据表格的宽度。
fixColumnSize
field
固定列尺寸。如果“field' 参数未指定,将所有列的大小固定。 示例:
$('#dg').datagrid('fixColumnSize', 'name'); // fix the 'name' column size
$('#dg').datagrid('fixColumnSize'); // fix all columns size
fixRowHeight
index
固定特定列的高度。如果“index' 参数未指定,将所有列的高度固定。
autoSizeColumn
field
自动调整列宽,以适应内容。此方法是1.3版本特有的。
loadData
data
载入本地数据,旧记录将被移除。
getData
none
返回已载入数据。
getRows
none
返回当前页的记录。
getFooterRows
none
返回行底记录。
getRowIndex
row
返回指定行的索引,row参数可以是行记录或者是一个id字段的值。
getChecked
none
返回所有行的复选框已被选中。此方法是1.3版本特有的。
getSelected
none
返回第一个被选择的行记录或null。
getSelections
none
返回所有被选择的行,当没有记录被选择时,将返回一个空数组。
clearSelections
none
取消所有的已选择项。
selectAll
none
选择所有页面的行。
unselectAll
none
取消选择所有页面的行。
selectRow
index
选择一行,行索引从0开始。
selectRecord
idValue
通过传递id参数来选择一行。
unselectRow
index
取消选择一行。
checkAll
none
检查所有页面的行。此方法是1.3版本特有的。
uncheckAll
none
取消检查所有当前页面的行。此方法是1.3版本特有的。
checkRow
index
检查行,行索引从0开始。此方法是1.3版本特有的。
uncheckRow
index
取消检查行,行索引从0开始。此方法是1.3版本特有的。
beginEdit
index
开始编辑一行。
endEdit
index
结束编辑。
cancelEdit
index
取消编辑。
getEditors
index
获取指定行的编辑器,每个编辑器有如下属性: actions:编辑器可以做的行为。 target:目标编辑器jQuery对象。 field:字段名。 type:编辑器类型。
getEditor
options
获取特定的编辑器,options参数有2个属性: index:行索引。 field:字段名。 示例:
// get the datebox editor and change its value
var ed = $('#dg').datagrid('getEditor', {index:1,field:'birthday'});
$(ed.target).datebox('setValue', '5/4/2012');
refreshRow
index
刷新一行。
validateRow
index
校验指定的行,如果有效返回true。
updateRow
param
更新指定的行,param参数包含如下属性: index:要更新的行索引。 row:新的行数据。 示例:
$('#dg').datagrid('updateRow',{
index: 2,
row: {
name: 'new name',
note: 'new note message'
}
});
appendRow
row
添加一行。 新的行会被添加到最后一个位置: $('#dg').datagrid('appendRow',{
name: 'new name',
age: 30,
note: 'some messages'
});
insertRow
param
插入一个新行,param参数包含如下属性: index:要插入的行索引,如果没有定义则在最后面添加一个新行。 row:行数据。
示例:
// insert a new row at second row position
$('#dg').datagrid('insertRow',{
index: 1, // index start with 0
row: {
name: 'new name',
age: 30,
note: 'some messages'
}
});
deleteRow
index
删除一行。
getChanges
type
获取从最后一次提交开始的被修改的所有行,type参数表明修改的类型,可选值:inserted,deleted,updated等 。当没有传递type参数时,返回所有被修改的行。
acceptChanges
none
提交所有修改的数据,提交后的数据将不能再修改或者回滚。
rejectChanges
none
回滚自创建以来或自上次调用AcceptChanges,所有的变化数据。
mergeCells
options
合并单元格,options参数包含如下属性: index:行索引。 field:字段名。 rowspan:整合单元格要跨的行数。 colspan:整合单元格要跨的列数。
showColumn
field
显示特定的列。
hideColumn
field
隐藏特定的列。
1 /////////////////////////////////////////////
2 //初始化数据
3 function initGrid()
4 {
5 $('#grid').datagrid({
6 width:'100%',
7 height:'auto',
8 nowrap: true,
9 striped: true,
10 fitColumns:false,
11 url:'${contextPath}/cardGift/cardGift.do?method=getCardGiftList&activeId=${information.cardGiftActive.activeId}',
12 queryParams:queryParam,
13 remoteSort:false,
14 //Grid对应的主键列
15 idField:'',
16 singleSelect:true,
17 columns:[[
18 {field:'serial',title:'',width:15,checkbox:true},
19 {field:'activeName',title:'活动名称',width:50,sortable:true},
20 {field:'giftGoodId',title:'赠品商品编码',width:80},
21 {field:'goodsName',title:'商品名称',width:120},
22 {field:'giftCodeTotal',title:'赠品码生成数量',width:100},
23 {field:'genCodeNumber',title:'已生成赠品码数量',width:100},
24 {field:'startTime',title:'赠品发放起始时间',width:125},
25 {field:'endTime',title:'赠品发放结束时间',width:125},
26 {field:'memo',title:'备注',width:120}
27 ]],
28 pagination:true,
29 rownumbers:true,
30 toolbar:[
31 '-',{
32 id:'btnClearSelections',
33 text:'修改活动商品',
34 iconCls:'icon-edit',
35 handler:function(){
36 editData();
37 }
38 },'-',{
39 id:'btnDel',
40 text:'删除活动商品',
41 iconCls:'icon-no',
42 handler:function(){
43 deleteData();
44 }
45 },
46 '-',{
47 id:'btnClearSelections',
48 text:'清除选择',
49 iconCls:'icon-cut',
50 handler:function(){
51 $('#grid').datagrid('clearSelections');
52 //设置选中值
53 document.addForm.reset();
54 $('#giftCodeTotal').val("0");
55 $('#memoData').html("");
56 $('#submitBtn').html("确认提交");
57 $('#submitBtn').attr('onclick',"addSubmit('insert');");
58 }
59 }],
60 onLoadError:function(){
61 XW_dialog.alert('','加载数据失败!');
62 }
63
64 });
65
66 //设置分页控件
67 var p = $('#grid').datagrid('getPager');
68 $(p).pagination(PAGE_TEMPLATE);
69 }
70
71
72 function editData(){
73 var row = $('#grid').datagrid("getSelections");
74 if($(row).length < 1 || $(row).length > 1)
75 {
76 XW_dialog.alert('',"请选择要查看的记录,只能选取单行!");
77 return ;
78 }
79 //设置默认选中
80 $('#goodsSelect').combogrid('grid').datagrid('selectRecord',row[0].giftGoodId);
81 $('#goodsSelect').hide();
82 //设置选中值
83 $('#giftCodeTotal').val(row[0].giftCodeTotal);
84 $('#memoData').html(row[0].memo);
85 $('#submitBtn').html("更新");
86 $('#submitBtn').attr('onclick',"addSubmit('update');");
87 $('#resetBtn').hide();
88
89 }
90
91
92 function deleteData(){
93 var data = $('#grid').datagrid("getSelections");
94 //删除
95 var delurl = "${contextPath}/cardGift/cardGift.do?method=deleteCardGift&activeId="+data[0].activeId+"&giftGoodId="+data[0].giftGoodId;
96 //发送删除请求
97 $.ajax({
98 type: "POST",
99 dataType:'json',
100 url: delurl,
101 success: function(msg){
102 if(msg.success)
103 {
104 //保存回调函数使用的数据
105 XW_dialog.addData('callbackData',msg.map);
106 //删除成功
107 XW_dialog.tips(msg.errorMsg, 3);
108 deleteCallBack();
109 }
110 else
111 {
112 XW_dialog.alert('',msg.errorMsg);
113 }
114 }
115 });
116 }
117
118
119 //删除记录回调函数,默认调用刷新记录方法,
120 function deleteCallBack(){
121 reloadGrid("grid");
122 }
123
你可能感兴趣的:(个人心得)
侯捷C++课程学习笔记:深入探索C++内存管理机制
清水白石008
c++ 学习 笔记
侯捷C++课程学习笔记:深入探索C++内存管理机制引言有幸参与“学C++,赢好礼”——侯捷C++系列精品课学习笔记征文活动,我深感荣幸。侯捷老师作为C++教育界的泰斗,其课程深入浅出,实战性强,引领我们开发者真正理解C++的精髓。在学习侯捷C++系列课程的过程中,我受益匪浅,尤其是在内存管理这一核心领域,更是有了系统而深刻的认识。本文将围绕侯捷C++课程的学习内容,结合个人心得体会,深入探讨C++
C#、ASP、ASP.NET、.NET、ASP.NET CORE区别、ASP.NET Core其概念和特点、ASP.NET Core个人心得体会
手中的风筝664
c# asp.net .net
C#是一种面向对象的编程语言,主要用于开发跨平台的应用程序。它是.NET框架的一部分,并且可以在.NET平台上运行。ASP(ActiveServerPages)是一种用于构建动态Web页面的技术,使用VBScript或JScript作为服务器端脚本语言。它是早期的Microsoft技术,现已逐渐过时。ASP.NET是微软推出的下一代Web应用程序开发技术,它提供了更强大、更高效的功能和工具。ASP
三下乡个人心得体会
m森屿a
为了拓展自身的知识面,扩大与社会的接触面,增加个人在社会竞争中的经验,锻炼和提高自己的能力,以便在以后毕业后能真正走入社会,并且能够在生活和工作中很好地处理各方面的问题,我们怀着同样的梦想参加了这次的社会活动,在活动中我们体会快乐,在活动中我们汲取更多的知识;!我们探望老人,关爱儿童;在活动中我们深入民心。参加暑期“三下乡”,我真的感到很荣幸。虽然是短短的半天,却是截然不同的体会。关爱孤寡老人留守
2022-10-18
喷香喷香的
幸福都是奋斗出来的10月16日,万众期待、举世瞩目的中国共产党第二十次全国代表大会在北京隆重开幕。与此同时,作为组工干部,普通党员的我也在党组织的带领下,集中观看了党的二十大。感触颇深,分享三点个人心得:一是党的十八大以来,党和国家事业之所以能够有效应对严峻复杂的国际形势和巨大风险挑战,取得重大历史成就,根本在于以习近平同志为核心的党中央坚强领导,在于习近平新时代中国特色社会主义思想的科学指引;二
C#、ASP、ASP.NET、.NET、ASP.NET CORE区别、ASP.NET Core其概念和特点、ASP.NET Core个人心得体会
lijingguang
C# c#
C#是一种面向对象的编程语言,主要用于开发跨平台的应用程序。它是.NET框架的一部分,并且可以在.NET平台上运行。ASP(ActiveServerPages)是一种用于构建动态Web页面的技术,使用VBScript或JScript作为服务器端脚本语言。它是早期的Microsoft技术,现已逐渐过时。ASP.NET是微软推出的下一代Web应用程序开发技术,它提供了更强大、更高效的功能和工具。ASP
Docx4j简单学习
deepDSM
文档生成 java xml 经验分享
前言:此文档简单记述在使用docx4j进行编程式生成文档元素的个人心得,故存在理解有误之处,还请指正!该项目是基于docx文档的xml结构,进行标签对象的赋值与取值,因此,当生成部分不常见元素时(比如无序项目编码时),可以参考xml文件中的属性,进行编码实现。比如文档中插入小标题,即文本添加导航功能:文档内容如下:对应解压文件document.xml即文档xml结构内容,styles.xml即为样
mysql菜鸟教程面向对象_第一节--面向对象编程
少年安吉
mysql菜鸟教程面向对象
第一节--面向对象编程发布时间:2016-06-17来源:点击:次+---------------------------------------------------------------------+|=本文为Haohappy读<>|=中ClassesandObjects一章的笔记|=翻译为主+个人心得|=为避免可能发生的不必要的麻烦请勿转载,谢谢|=欢迎批评指正,希望和所有PHP爱好者共
复盘学习第三天
莫色阿可儿
2020年12月16日星期一复盘第三天阅读训练营第三天复盘昨天收到助教彭双梅妹妹的邀请,让我参加今天小伙伴们的分享个人心得,有点激动,昨晚明明想好了要怎么做好这几分中的精彩分享,结果行动了来的结果,糟糕透了,不过还是努力安慰自己,你已经迈出了第一步,已经算在进步,如果没有这个平台这个机会,你永远觉得自己应该是想象中自己给自己定的标签归为优秀的人之类中,而真实的自己是一直就躺在那里一直活着很多年,所
前端学习个人心得,总结(个人向)
独醉于笙
学习 css css3
一、外边距合并1.出现的条件只有垂直方向的外边距会出现合并,水平方向上不会出现外边距合并。垂直方向上相邻的元素才会有外边距合并的问题。2.有两种情况2.1兄弟元素间的外边距合并(1)若两者都是正值,取值为两者间最大值(2)若两个外边距一正一负,取值为两者之和(3)若两个外边距都是负值,取值为绝对值较大的外边距解决方案:一般不需要处理,这一般是对开发有利的,如果要处理,可以将本应该设置给两个元素的外
页面置换算法的个人心得
沙漠炫神
算法
最近复习到了页面置换算法忍不住写一篇FIFO先进先出算法,这个不是FIFA,虽然看着很像,算法是先进先出规则,加入驻留级只有3个,我们可以假设有一张桌子TT大概就是这样桌子上能放得下最多3个数字,放置方式就是从一边推过去,如果满了必然会把最外面的推下去比如这么一串访问串12341513426我们将它从右边推到桌子上,就是123,之后把4推过去1就被挤掉了变成了234,如此反复fifo是不会改变顺序
2020-09-08星期三论语学习第七天贤贤易色
善一峰
子夏曰:“贤贤易色;事父母,能竭其力;事君,能致其身;与朋友交,言而有信。虽曰未学,吾必谓之学矣。译:子夏说,对妻子,看重品德而不是容貌;侍奉父母,能够竭尽全力;服务君主,能够豁出生命;同朋友交往,说话诚实信用。这一类人,虽说没有学习过圣人之言,我却一定说他们已经学习过了。个人心得:始于颜值,敬于才华,合于性格,久于善良,终于人品。和一个人交往一开始,我们是被美丽的外表给所吸引,但是让我们走很远的
python并发处理机制_Python基础教程之利用期物处理并发
weixin_39646405
python并发处理机制
前言抨击线程的往往是系统程序员,他们考虑的使用场景对一般的应用程序员来说,也许一生都不会遇到……应用程序员遇到的使用场景,99%的情况下只需知道如何派生一堆独立的线程,然后用队列收集结果。本文章记录了本人在学习Python基础之控制流程篇的重点知识及个人心得,打算入门Python的朋友们可以来一起学习并交流。本文重点:1、掌握异步编程的相关概念;2、了解期物future的概念、意义和使用方法;3、
2020-04-05
2c7f9befb359
【书籍】《低风险创业》第5~7章+附录【题目】任何时候都要提高自己的反脆弱能力【字数】01做自己影响圈内的事千万不要对自己一无所知的行业进行投资,想做一个行业,先让自己成为这个行业的专家,在自己能力圈之内创业,再不断的扩大自己的影响圈,并要给员工赋能,让他们也成为专家。02让客户帮忙带客户服务好每个客户,让客户有极致体验,心甘情愿的为你宣传,如果有可能让客户参与销售。03个人心得与计划投钱就可以挣
A002-185-2508-黄奕琛
Airili
需求分析课程 #需求分析个人作业
作业报告课程名称软件需求分析与建模班级18软5作业名称期末个人专题报告教导教师董瑞生姓名黄奕琛学号1814080902508日期2020.12.18目录1.名词解释与根据项目理解2.个人心得3.发展建议1.名词解释与根据项目理解1.Requirementsbaseline官方解释:Arequirementsbaselineisasnapshotintimethatrepresentsanagree
专才还是通才
AliceWanderAI
一些人企图用穷极知识的方法去追踪技术进步,努力使自己由专才演变为通才,这实在是一种机械论者美好而无法实现的愿望。以上摘自《军官素质论》个人心得:对于上面的建议,我早有切身体会,但我仍旧每日寻求对世界新的认识。这种无法实现的愿望,作为一个虚无的胜利旗帜,时刻引诱我靠近它。明白我无法完成这种事业,其中却还是充满乐趣。吾生也有涯,而知也无涯。
我的机械键盘之路
sigmarising
时至今日,我所拥有和使用过的机械键盘已经不在少数了。一直以来我都想写一篇日志记录一下,但无奈于事务繁杂,一直都没有时间,但最终总算挤出些许时间完成了这一篇文章,所以也在此分享一下我的个人心得和体会。我使用的第一把机械键盘是CherryMX1.0TKL,它采用ABS涂层键帽,内置钢板,轴体为老版的Cherry红轴。键盘的白色背光灯为正装,不存在卡键问题。由于这把键盘买的很早,它的PCB使用的是MX8
《认知天性》内容提要
平凡的云姐
《认知天性》这本书是由11位认知心理学家10年的科研心血。以罗迪格教授为主要负责人的团队在项目上投入了10年时间,首次提出了人类认知规律和学习之间的紧密联系,透彻解读人类普遍的学习过程规律。以下是我提炼的个人心得,需要了解的朋友请自取。1.当今的社会正变得越来越复杂,越来越不确定,越来越模糊,我们得以安身立命的法宝——终身学习。2.学习最大的敌人不是犯错,而是害怕犯错。错误的根本不是失败,而是通往
软件产品设计心得与体会及学习经验
m0_70844517
设计规范
个人心得:用户研究至关重要。在设计软件产品时,需要了解用户的需求和问题,这样才能开发出符合用户期望的产品。人们使用软件产品的目的很多,有些人希望能够提高生产效率,有些人希望获得娱乐,有些人希望能够方便地查询信息等等。因此,软件产品的设计都需要从用户的角度出发。把用户体验放在首要位置。一个好的软件产品除了功能齐全之外,还需要有良好的用户体验。一个优秀的用户体验能够增强用户的使用信心和满意度,使其更加
Android-针对Dao层的单元测试
Jeremy_Ji
Android的单元测试大家都不陌生,必要的单元测试可以提高工作效率,省去大量的在Android真机或者虚拟机上的调试,提高代码质量。尤其是在团队项目开发中,为自己写的代码负责,提高项目后期的可维护性。这篇文章算是个人心得体会吧。前几天接了一个任务就是对团队中现有的一个项目的dao层写单元测试(数据访问对象),该项目中的数据库适配器(MyDataBaseAdapter)中集成了大量的关于数据库中增
小白健身,如何选择一个靠谱专业的私教?
我滚呀滚雪球
01想健身要不要请私教?如何选择一个靠谱专业的私教?个人心得,仅供参考。我是从2014年开始健身,断断续续4年的时间,2016年跑过一场马拉松,2018年6月怀孕。因为怀孕之前一直有坚持锻炼的习惯,在微博也看到很多健身博主怀孕期间是有坚持健身的。所以,为了始终保持运动的习惯,从孕初期到孕中期,到现在孕8个月,我也有一直坚持健身。02在健身房锻炼的过程中,经常会遇到一些健身小白,有的是附近的大学生,
历史学科如何命制一套有质量的试题
抚今望昔
命题既是一门技术,也是一门艺术。历史学科如何命制一套有质量的试题呢?本文就个人心得谈一管之见。一、命题方向引导教学改革在国家意志层面,教育方针指导教育教学,指导命题方向,为新时代社会主义国家建设和发展培养、选拔人才。市教科所领导指出:在当前教育教学改革大势所趋,而仍然以考试为选拔人才的主要依据的特殊背景下。很多老师压着学生背书,回到20年前的教学模式,这是逆潮流的。那么如何在当下真正做到立德树人,
基于eclipse的登陆拦截小应用(未登录不得浏览网页内部)详解版
软件开发技术局
个人学习 eclipse servlet java
个人心得:本人是一个普通211学生,最近看到互联网行业就业压力巨大,不断思考自己进步的空间,趁着放假将以前课上做的web网页完善一下,当时因为办的免听错过了一些重要的内容,老师当时问我这个你用session了吗?我直接懵掉,session是个啥?所以期末成绩也没有90分,只得了87,就因为这个细节扣了很多,今日无事,决定学习如何提高网页的安全性。先上项目目录:再上我写这个工程的项目文件,至于每个文
2020.9.8论语学习第六天,入则孝
善一峰
子曰:“弟子,入则孝,出则悌,谨而信,泛爱众,而亲仁;行有余力,则以学文。”译:孔子说:弟子们在父母跟前,就孝顺父母;出门在外,要顺从师长,言行要谨慎,要诚实可信,要广泛地去爱众人,亲近那些有仁德的人。这样实践之后,还有余力的话,就再去学习文献知识。个人心得:何为真孝?是不是只要给父母吃饱穿暖就是真孝,这个回答显然是否定的,看见王阳明的书上写到,真正的孝是不让父母担心,这个担心要包含了多少,父母对
《大师Mike Cohn分享敏捷利器使用者的故事》活动分享心得
舞蕙
本次活动主要通过问答方式开展,通过会议的主持人提出实际问题,MikeCohn大师进行针对性的解答。分享内容及个人心得如下:分享内容1、MikeCohn:使用者故事的起源——最初起源于非IT行业,一个美国的企业工资发放系统,为了了解系统的使用情况,系统人员向客户询问其实际需求是什么样子,从而来优化系统用以方便用户使用。最初用户故事被用来了解使用者的感受,他们想要什么样子的。收集使用者需求,通过使用者
关于学习《道德经》的一些个人体悟
天蝎座的书生
这篇文章,我打算分为两个部分来进行述说,只是我的一些个人看法和心得体会。至于是对的还是错的,这需要你自己去思考判断。第一部分是我的学习观,或者说我对学习的一些看法;第二部分是我学习《道德经》后的一些个人心得体会和领悟。至于你从中收获领悟到什么,我也不知道,也不要被我的一些观点和看法所影响。依然是那句话,你自己去斟酌判断。我认为学习的本质是修道,或者说修大学之道。由于我自己只是刚刚入门,懂得一点皮毛
甲骨文三下乡之个人心得体会
丶碎忆
一撇一捺总关情,一横一竖传文脉。历经三千多年的时间洗礼而不朽的甲骨文,是汉字的源头,是千年中华文明的标志,具有崇高的象征意义。今年暑假我加入了由安阳工学院生物与食品工程学院发起的“安阳甲骨文化体验式传播”三下乡社会实践队。这次的甲骨文三下乡社会实践活动是一个非常有意义的事,我们几位志愿者在指导老师的带领下参观了甲骨文碑、甲骨馆以及甲骨文文献。这虽说是我第⼀次参加社会实践,但我认为将会对我以后的学习
《有限责任家庭》极简读书笔记
小铭的笔记本
//作者:李雪//小铭曰:本笔记为个人心得,不完全体现原书内容,仅供参考(1)不只是婚姻关系,在任何关系中,一旦有一方总觉得自己在为对方付出,那这个人就已经丧失了主体性,爱也就不存在了,只剩下道德资本累积起来的愤怒和痛苦。(2)真正的善意是无论结果如何,都为自己负责——“我向这个世界发出善意,得到回应很好;没有回应,我也保持了内在的宽广和平静”。(3)臣服于真相,允许一切发生(4)强迫症是一种心理
课后总结1-如何打造高质量的应用
迷途小顽童
导读:最近在学习张绍文的“Android开发高手课”,该课程是一门为Android开发者量身定制的进阶课程,围绕打造高质量应用、实现高效开发和架构演进这三部分,不仅包含图文、音频的教学,还有作者精心设计的练习Sample,帮助你快速掌握解决复杂问题的思路和方法,并能结合课后实践切实提升开发能力,该栏目主要为本人学习该课程的一些总结及个人心得。1、Android中分析内存工具Traceview2、目
聊聊我眼中的大神——弗洛伊德和精神分析
老蜗的壳
原本昨天就打算开笔写点关于心理学,关于心理学家的个人心得。计划先从我最感兴趣的弗罗伊德与精神分析开始。于是首先打开了课本,重新学习了有关内容。发现要讲清楚这个人,就必须要了解心理学的发展史,于是又翻看了心理学史的相关内容。而单一学科的历史,又不足以从宏观的角度进行描述,于是又翻看了世界史的相关内容。而对于理论的分析,又不能离开哲学背景,于是又翻看了哲学史的相关内容。当这一切结束的时候,脑子中已是一
面对地产客户,如何沟通协调才能推进项目?『个人心得』
朱朱说生活美学
关于地产行业,用高压力和强加班来形容也不为过。面对地产客户,工作日和双休日没有区别,因为工作在加班,双休还在加班,没有最辛苦只有更辛苦。别人节假日在旅游,而你依然在加着班,不是写PPT就是扮演着AE的角色,又或者撰写突如其来的稿件。我相信每一个服务地产项目的人,其中心情自己最了解。那么问题来了,面对地产客户,如何沟通协调才能推进项目顺利进行呢?作为编辑的我,就给大家讲讲自己的心得体会,仅供参考。问
继之前的线程循环加到窗口中运行
3213213333332132
java thread JFrame JPanel
之前写了有关java线程的循环执行和结束,因为想制作成exe文件,想把执行的效果加到窗口上,所以就结合了JFrame和JPanel写了这个程序,这里直接贴出代码,在窗口上运行的效果下面有附图。
package thread;
import java.awt.Graphics;
import java.text.SimpleDateFormat;
import java.util
linux 常用命令
BlueSkator
linux 命令
1.grep
相信这个命令可以说是大家最常用的命令之一了。尤其是查询生产环境的日志,这个命令绝对是必不可少的。
但之前总是习惯于使用 (grep -n 关键字 文件名 )查出关键字以及该关键字所在的行数,然后再用 (sed -n '100,200p' 文件名),去查出该关键字之后的日志内容。
但其实还有更简便的办法,就是用(grep -B n、-A n、-C n 关键
php heredoc原文档和nowdoc语法
dcj3sjt126com
PHP heredoc nowdoc
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Current To-Do List</title>
</head>
<body>
<?
overflow的属性
周华华
JavaScript
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml&q
《我所了解的Java》——总体目录
g21121
java
准备用一年左右时间写一个系列的文章《我所了解的Java》,目录及内容会不断完善及调整。
在编写相关内容时难免出现笔误、代码无法执行、名词理解错误等,请大家及时指出,我会第一时间更正。
&n
[简单]docx4j常用方法小结
53873039oycg
docx
本代码基于docx4j-3.2.0,在office word 2007上测试通过。代码如下:
import java.io.File;
import java.io.FileInputStream;
import ja
Spring配置学习
云端月影
spring配置
首先来看一个标准的Spring配置文件 applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi=&q
Java新手入门的30个基本概念三
aijuans
java 新手 java 入门
17.Java中的每一个类都是从Object类扩展而来的。 18.object类中的equal和toString方法。 equal用于测试一个对象是否同另一个对象相等。 toString返回一个代表该对象的字符串,几乎每一个类都会重载该方法,以便返回当前状态的正确表示.(toString 方法是一个很重要的方法) 19.通用编程:任何类类型的所有值都可以同object类性的变量来代替。
《2008 IBM Rational 软件开发高峰论坛会议》小记
antonyup_2006
软件测试 敏捷开发 项目管理 IBM 活动
我一直想写些总结,用于交流和备忘,然都没提笔,今以一篇参加活动的感受小记开个头,呵呵!
其实参加《2008 IBM Rational 软件开发高峰论坛会议》是9月4号,那天刚好调休.但接着项目颇为忙,所以今天在中秋佳节的假期里整理了下.
参加这次活动是一个朋友给的一个邀请书,才知道有这样的一个活动,虽然现在项目暂时没用到IBM的解决方案,但觉的参与这样一个活动可以拓宽下视野和相关知识.
PL/SQL的过程编程,异常,声明变量,PL/SQL块
百合不是茶
PL/SQL的过程编程 异常 PL/SQL块 声明变量
PL/SQL;
过程;
符号;
变量;
PL/SQL块;
输出;
异常;
PL/SQL 是过程语言(Procedural Language)与结构化查询语言(SQL)结合而成的编程语言PL/SQL 是对 SQL 的扩展,sql的执行时每次都要写操作
Mockito(三)--完整功能介绍
bijian1013
持续集成 mockito 单元测试
mockito官网:http://code.google.com/p/mockito/,打开documentation可以看到官方最新的文档资料。
一.使用mockito验证行为
//首先要import Mockito
import static org.mockito.Mockito.*;
//mo
精通Oracle10编程SQL(8)使用复合数据类型
bijian1013
oracle 数据库 plsql
/*
*使用复合数据类型
*/
--PL/SQL记录
--定义PL/SQL记录
--自定义PL/SQL记录
DECLARE
TYPE emp_record_type IS RECORD(
name emp.ename%TYPE,
salary emp.sal%TYPE,
dno emp.deptno%TYPE
);
emp_
【Linux常用命令一】grep命令
bit1129
Linux常用命令
grep命令格式
grep [option] pattern [file-list]
grep命令用于在指定的文件(一个或者多个,file-list)中查找包含模式串(pattern)的行,[option]用于控制grep命令的查找方式。
pattern可以是普通字符串,也可以是正则表达式,当查找的字符串包含正则表达式字符或者特
mybatis3入门学习笔记
白糖_
sql ibatis qq jdbc 配置管理
MyBatis 的前身就是iBatis,是一个数据持久层(ORM)框架。 MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架。MyBatis对JDBC进行了一次很浅的封装。
以前也学过iBatis,因为MyBatis是iBatis的升级版本,最初以为改动应该不大,实际结果是MyBatis对配置文件进行了一些大的改动,使整个框架更加方便人性化。
Linux 命令神器:lsof 入门
ronin47
lsof
lsof是系统管理/安全的尤伯工具。我大多数时候用它来从系统获得与网络连接相关的信息,但那只是这个强大而又鲜为人知的应用的第一步。将这个工具称之为lsof真实名副其实,因为它是指“列出打开文件(lists openfiles)”。而有一点要切记,在Unix中一切(包括网络套接口)都是文件。
有趣的是,lsof也是有着最多
java实现两个大数相加,可能存在溢出。
bylijinnan
java实现
import java.math.BigInteger;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class BigIntegerAddition {
/**
* 题目:java实现两个大数相加,可能存在溢出。
* 如123456789 + 987654321
Kettle学习资料分享,附大神用Kettle的一套流程完成对整个数据库迁移方法
Kai_Ge
Kettle
Kettle学习资料分享
Kettle 3.2 使用说明书
目录
概述..........................................................................................................................................7
1.Kettle 资源库管
[货币与金融]钢之炼金术士
comsci
金融
自古以来,都有一些人在从事炼金术的工作.........但是很少有成功的
那么随着人类在理论物理和工程物理上面取得的一些突破性进展......
炼金术这个古老
Toast原来也可以多样化
dai_lm
android toast
Style 1: 默认
Toast def = Toast.makeText(this, "default", Toast.LENGTH_SHORT);
def.show();
Style 2: 顶部显示
Toast top = Toast.makeText(this, "top", Toast.LENGTH_SHORT);
t
java数据计算的几种解决方法3
datamachine
java hadoop ibatis r-langue r
4、iBatis
简单敏捷因此强大的数据计算层。和Hibernate不同,它鼓励写SQL,所以学习成本最低。同时它用最小的代价实现了计算脚本和JAVA代码的解耦,只用20%的代价就实现了hibernate 80%的功能,没实现的20%是计算脚本和数据库的解耦。
复杂计算环境是它的弱项,比如:分布式计算、复杂计算、非数据
向网页中插入透明Flash的方法和技巧
dcj3sjt126com
html Web Flash
将
Flash 作品插入网页的时候,我们有时候会需要将它设为透明,有时候我们需要在Flash的背面插入一些漂亮的图片,搭配出漂亮的效果……下面我们介绍一些将Flash插入网页中的一些透明的设置技巧。
一、Swf透明、无坐标控制 首先教大家最简单的插入Flash的代码,透明,无坐标控制: 注意wmode="transparent"是控制Flash是否透明
ios UICollectionView的使用
dcj3sjt126com
UICollectionView的使用有两种方法,一种是继承UICollectionViewController,这个Controller会自带一个UICollectionView;另外一种是作为一个视图放在普通的UIViewController里面。
个人更喜欢第二种。下面采用第二种方式简单介绍一下UICollectionView的使用。
1.UIViewController实现委托,代码如
Eos平台java公共逻辑
蕃薯耀
Eos平台java公共逻辑 Eos平台 java公共逻辑
Eos平台java公共逻辑
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
蕃薯耀 2015年6月1日 17:20:4
SpringMVC4零配置--Web上下文配置【MvcConfig】
hanqunfeng
springmvc4
与SpringSecurity的配置类似,spring同样为我们提供了一个实现类WebMvcConfigurationSupport和一个注解@EnableWebMvc以帮助我们减少bean的声明。
applicationContext-MvcConfig.xml
<!-- 启用注解,并定义组件查找规则 ,mvc层只负责扫描@Controller -->
<
解决ie和其他浏览器poi下载excel文件名乱码
jackyrong
Excel
使用poi,做传统的excel导出,然后想在浏览器中,让用户选择另存为,保存用户下载的xls文件,这个时候,可能的是在ie下出现乱码(ie,9,10,11),但在firefox,chrome下没乱码,
因此必须综合判断,编写一个工具类:
/**
*
* @Title: pro
挥洒泪水的青春
lampcy
编程 生活 程序员
2015年2月28日,我辞职了,离开了相处一年的触控,转过身--挥洒掉泪水,毅然来到了兄弟连,背负着许多的不解、质疑——”你一个零基础、脑子又不聪明的人,还敢跨行业,选择Unity3D?“,”真是不自量力••••••“,”真是初生牛犊不怕虎•••••“,••••••我只是淡淡一笑,拎着行李----坐上了通向挥洒泪水的青春之地——兄弟连!
这就是我青春的分割线,不后悔,只会去用泪水浇灌——已经来到
稳增长之中国股市两点意见-----严控做空,建立涨跌停版停牌重组机制
nannan408
对于股市,我们国家的监管还是有点拼的,但始终拼不过飞流直下的恐慌,为什么呢?
笔者首先支持股市的监管。对于股市越管越荡的现象,笔者认为首先是做空力量超过了股市自身的升力,并且对于跌停停牌重组的快速反应还没建立好,上市公司对于股价下跌没有很好的利好支撑。
我们来看美国和香港是怎么应对股灾的。美国是靠禁止重要股票做空,在
动态设置iframe高度(iframe高度自适应)
Rainbow702
JavaScript iframe contentDocument 高度自适应 局部刷新
如果需要对画面中的部分区域作局部刷新,大家可能都会想到使用ajax。
但有些情况下,须使用在页面中嵌入一个iframe来作局部刷新。
对于使用iframe的情况,发现有一个问题,就是iframe中的页面的高度可能会很高,但是外面页面并不会被iframe内部页面给撑开,如下面的结构:
<div id="content">
<div id=&quo
用Rapael做图表
tntxia
rap
function drawReport(paper,attr,data){
var width = attr.width;
var height = attr.height;
var max = 0;
&nbs
HTML5 bootstrap2网页兼容(支持IE10以下)
xiaoluode
html5 bootstrap
<!DOCTYPE html>
<html>
<head lang="zh-CN">
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">