easyui 懂的进 我要设置easyui-datagrid 如何设置

easyui 懂的进 我要设置easyui-datagrid 如何设置,第1张

但可以确保各个版块相互独立,总共4个部分1数据绑定2DataGrid的增改删功能3DataGrid的分页实现4DataGrid的样式设计先上一张截图,让你大概知道自己需要的功能是否在这张图里有所实现。PS:使用技术:WPF+ADONETEntityFramework1数据绑定(涉及DataGrid绑定和Combox绑定)在DataGrid中同时包含逗自动生成列地与逗用户自定义列地由属性AutoGenerateColumns控制。默认情况下,DataGrid将根据数据源自动生成列。下图列出了生成的列类型。如果AutoGenerateColumns="True",我们只需要如下几行代码后台dataGrid1ItemsSource=infoList;//infoList为内容集合(这是我从数据库中获取的记录集合类型为List)PS:因为这里给dataGrid1绑定了数据源,所以下面绑定的字段都是infoList中的字段名称,同样也对应着我数据表中的字段名。里面包含FID,公司名称,职员姓名,性别,年龄,职务。解释下,怕大家无法理解Binding后面的值是如何来的了显然这种数据绑定非常的容易,如果对表格要求不高,这中无疑是最简单方便的。如果AutoGenerateColumns="False"表格字段的显示就要靠我们手动去完成了。这个也是数据绑定的重点,因为实际应用中我们大多都是自定义去完成DataGrid的数据绑定。接下来贴出代码(后面的所有功能都可以在此代码基础上添加和修改)后台namespaceDemo{//////MainWindowxaml的交互逻辑///publicenumSex{男,女};//注意写在命名空间内,不要写在类里,否则台前local:Sex找不到路径}当我们绑定好数据运行程序的时候,会发现DataGridComboBoxColumn下拉框里虽然绑定了值,但是他不会默认显示出已经设定好的值。所以我们就可以摈弃这种现有的DataGridComboBoxColumn,我们用DataGrid样板标签DataGridTemplateColumn。我们在DataGridTemplateColumn标签里要用到2个控件,一个TextBlock控件来显示内容,另一个ComBox来提供选择。所以我们可以用如下代码替换掉注意CellTemplate和CellEditingTemplate的区别2DataGrid的增改删功能①添加记录行+编辑记录行由于增加和编辑有一定的联系,所以就放一起来讨论在上面的代码处添加2个Button按钮,DataGrid默认是输入一行记录后自动会生成一个新行(类似MSSQL数据库添加表记录)。由属性CanUserAddRows来控制当CanUserAddRows=false的时候就不会自动生成新行。为了方便我们自己来控制,所以在DataGrid里面设置CanUserAddRows为false后台事件intjudge=0;//0表示编辑状态,1为添加状态。因为后面的增加和编辑都在同一个事件中,所以建一个变量来区分 *** 作TB_InformationtbInfo=newTB_Information();//这个类可以供我调用里面的方法来进行增删改查的 *** 作privatevoidbtnAdd_Click(objectsender,RoutedEventArgse){judge=1;//现在为添加状态dataGrid1CanUserAddRows=true;//点击添加后将CanUserAddRows重新设置为True,这样DataGrid就会自动生成新行,我们就能在新行中输入数据了。}//现在我们可以添加新记录了,我们接下来要做的就是获取这些新添加的记录//先声明一个存储新建记录集的List这里的Information是我的数据表实体类里面包含FID,公司名称,职员姓名,性别,年龄,职务ListlstInformation=newList();//我们通过RowEditEnding来获取新增的记录,就是每次编辑完行后,行失去焦点激发该事件。更新记录也是执行该事件privatevoiddataGrid1_RowEditEnding(objectsender,DataGridRowEditEndingEventArgse){Informationinfo=newInformation();//我自己的数据表实例类info=eRowItemasInformation;//获取该行的记录if(judge==1)//如果是添加状态就保存该行的值到lstInformation中这样我们就完成了新行值的获取{lstInformationAdd(info);}else{tbInfoUpdInformation(info);//如果是编辑状态就执行更新 *** 作更新 *** 作最简单,因为你直接可以在DataGrid里面进行编辑,编辑完成后执行这个事件就完成更新 *** 作了}}//获取到记录后,单击保存按钮就可以保存lstInformation中的每一条记录privatevoidbtnSave_Click(objectsender,RoutedEventArgse){foreach(InformationinfoinlstInformation){tbInfoInsInformation(info);//执行插入方法,将记录保存到数据库}judge=0;//重新回到编辑状态lstInformationClear();dataGrid1CanUserAddRows=false;//因为完成了添加 *** 作所以设置DataGrid不能自动生成新行了Binding(Num,1);}这里又会遇到一个问题。那就是更新数据的时候,发现数据更本就没更新。跟踪代码会发现后台得到的值还是原来的,无法获取编辑后的值。这个问题就是绑定模式的问题,我们只需设置双向绑定就可以了。且作用对象是在属性值更改的情况下进行双向绑定。只要在前面的每个表字段处加上Mode=TwoWay,UpdateSourceTrigger=PropertyChanged问题就解决了例如:②删除记录为了有良好的用户体验,我就做了个可以批量删除的删除功能。就是利用到CheckBox控件来完成。以绑定代码为基础添加代码首先我们要获取CheckBox中的值,有哪些是被选中的。显然CheckBox里面还必须绑定值,并且还需要一个事件。给CheckBox添加的代码如下后台代码//由ChecBox的Click事件来记录被选中行的FIDListselectFID=newList();//保存选中要删除行的FID值privatevoidCheckBox_Click(objectsender,RoutedEventArgse){CheckBoxdg=senderasCheckBox;intFID=intParse(dgTagToString());//获取该行的FIDvarbl=dgIsChecked;if(bl==true){selectFIDAdd(FID);//如果选中就保存FID}else{selectFIDRemove(FID);//如果选中取消就删除里面的FID}}//已经获取到里面的值了,接下来就只要完成删除 *** 作就可以了删除事件如下privatevoidbtnDelete_Click(objectsender,RoutedEventArgse){foreach(intFIDinselectFID){tbInfoDelInformation(FID);//循环遍历删除里面的记录}//Binding(Num,1);//这个是我绑定的一个方法,作用是删除记录后重新给DataGrid赋新的数据源}3DataGrid的分页实现原理:其实分页功能的实现大家都清楚,无非就是把一个记录集通过运算来刷选里面对应页码的记录。接来下我们再次添加新的代码首先我们先写个分页的方法,供上面这些事件调用后台代码//number表示每个页面显示的记录数currentSize表示当前显示页数privatevoidBinding(intnumber,intcurrentSize){ListinfoList=newList();infoList=tbInfoGetInformationList();//获取数据源intcount=infoListCount;//获取记录总数intpageSize=0;//pageSize表示总页数if(count%number==0){pageSize=count/number;}else{pageSize=count/number+1;}tbkTotalText=pageSizeToString();tbkCurrentsizeText=currentSizeToString();infoList=infoListTake(numbercurrentSize)Skip(number(currentSize-1))ToList();//刷选第currentSize页要显示的记录集dataGrid1ItemsSource=infoList;//重新绑定dataGrid1}//分页方法写好了接下来就是响应下一页,上一页,和跳转页面的事件了//先定义一个常量constintNum=12;//表示每页显示12条记录//上一页事件privatevoidbtnUp_Click(objectsender,RoutedEventArgse){intcurrentsize=intParse(tbkCurrentsizeText);//获取当前页数if(currentsize>1){Binding(Num,currentsize-1);//调用分页方法}}//下一页事件privatevoidbtnNext_Click(objectsender,RoutedEventArgse){inttotal=intParse(tbkTotalText);//总页数intcurrentsize=intParse(tbkCurrentsizeText);//当前页数if(currentsize=1&&pageNum(dataGrid_LoadingRow);//自动添加序号的事件调用下面的dataGrid_LoadingRow}publicvoiddataGrid_LoadingRow(objectsender,DataGridRowEventArgse){eRowHeader=eRowGetIndex()+1;//设置行表头的内容值}接下来就可以修改行表头的颜色了②给列表头添加颜色③给行添加颜色+滑鼠事件lt;/DataGrid>④给单元格添加颜色⑤让用户在单元格获得焦点时编辑ComboBox其实这不属于样式的范畴了,但我喜欢把改善用户体验归于这一类。当我们的表格里有类似ComboBox的控件时(如:DatePicker控件等)。我们编辑这些控件时,首先第一次单击获取单元格焦点,第二次点击才能获取编辑时的焦点,也就是用户必须单击2次才能进行 *** 作。这种机制其实是适合文本框控件的,但对于其它控件,像ComboBox就显得很不方便了。所以我们要做的就是单击第一次的时候用户就可以编辑ComboBox。接下来我要在DataGrid添加了三个新属性(RowDetailsVisibilityMode、SelectionMode和SelectionUnit)和一个新的事件处理程序(SelectedCellsChanged)前台后台现在就差一个SelectedCellsChanged(选则单元格时出发该事件)事件的后台代码了privatevoiddataGrid1_SelectedCellsChanged(objectsender,SelectedCellsChangedEventArgse)if(eAddedCellsCount==0)return;varcurrentCell=eAddedCells[0];if(currentCellColumn==dataGrid1Columns[3])//Columns[]从0开始我这的ComboBox在第四列所以为3{dataGrid1BeginEdit();//进入编辑模式这样单击一次就可以选择ComboBox里面的值了}⑥固定列表头这个非常简单只要在DataGrid里添加一个属性即可

你好!!

这个通过配置无法解决,只能手工干预啦~~

下面代码可供参考:

javascript:

<script>

        $(function(){

            $('#tt')datagrid({

                onLoadSuccess:function(data){

                    //获取表头第3列的div

                    var _div =     $("datagrid-header-row td:eq(3) div");

                    

                    // *** 作表头第4列对象,将宽度调宽,追加第3列的div,设置居中及文本

                    $("datagrid-header-row td:eq(4)")

                            css("width",160)

                                append(_div)

                                    attr("align","center")

                                        text("收油计划日期");

                    

                    //设置表头第3列对象宽度为0

                    $("datagrid-header-row td:eq(3)")css("width",0);

                    _div = null;

                }

            });

        })

    </script>

html:

<table id="tt" class="easyui-datagrid" title="Column Group" style="width:700px;height:250px"

       data-options="rownumbers:true,singleSelect:true,url:'/datagrid/datagrid_data1json'">

    <thead>

    <tr>

        <th data-options="field:'itemid',width:80" >Item ID</th>

        <th data-options="field:'productid',width:100" >Product</th>

        <th data-options="field:'listprice',width:80,align:'right'" ></th>

        <th data-options="field:'unitcost',width:80,align:'center'" ></th>

        <th data-options="field:'attr1',width:240,align:'center'" >Attribute</th>

        <th data-options="field:'status',width:60,align:'center'" >Status</th>

    </tr>

    </thead>

</table>

代码很容易读懂·····

希望对你有帮助!!!!

废话俺就少说了,直接进入正题!!单纯的JS能够导出Excel的不多见,一般都需要调用客户端所安装的Office

Excel组件来完成这个工作。这里我主要讲EasyUI内的DataGrid如何结合JS导出Excel文件

一、

导出Excel的核心代码段如下所示

function

Exproter()

{

//获取Datagride的列

var

rows

=

$('#test')datagrid('getRows');

var

oXL

=

new

ActiveXObject("ExcelApplication");

//创建AX对象excel

var

oWB

=

oXLWorkbooksAdd();

//获取workbook对象

var

oSheet

=

oWBActiveSheet;

//激活当前sheet

for

(var

i

=

0;

i

<

rowslength;

i++)

{

oSheetCells(i

+

1,

1)value

=

rows[i]O_NAME;

}

oXLVisible

=

true;

//设置excel可见属性

}

二、以上JS方法能够顺利执行的大前提就是

1机器上Excel已经安装

2Internet

选项=>安全=>Internet

\"对没有标记为安全的ActiveX控件进行初始化和脚本运行,设定为启用\"

//EasyUI

datagrid

动态导出Excel

function

ExporterExcel()

{

//获取Datagride的列

var

rows

=

$('#tt')datagrid('getRows');

var

columns

=

$("#tt")datagrid("options")columns[0];

var

oXL

=

new

ActiveXObject("ExcelApplication");

//创建AX对象excel

var

oWB

=

oXLWorkbooksAdd();

//获取workbook对象

var

oSheet

=

oWBActiveSheet;

//激活当前sheet

//设置工作薄名称

oSheetname

=

"导出Excel报表";

//设置表头

for

(var

i

=

0;

i

<

columnslength;

i++)

{

oSheetCells(1,

i+1)value

=

columns[i]title;

}

//设置内容部分

for

(var

i

=

0;

i

<

rowslength;

i++)

{

//动态获取每一行每一列的数据值

for

(var

j

=

0;

j

<

columnslength;

j++)

{

oSheetCells(i

+

2,

j+1)value

=

rows[i][columns[j]field];

}

}

oXLVisible

=

true;

//设置excel可见属性

}

以上就是小编为大家带来的EasyUI

结合JS导出Excel文件的实现方法全部内容了,希望大家多多支持脚本之家~

java怎么获取easyui中时间控制元件的值

java获取easyui中时间控制元件的值很简单:

var v = $('#dd')datebox('getValue');

jquery-1102minjs怎么获取easyui的时间控制元件的值

jquery-1102minjs怎么获取easyui的时间控制元件的值

基本用法:

1) 加入日期选择框

$("#dd")datebox({"required":true});

2) javascript获取日期选择框的值

$("#dd")datebox("getValue"); 或者$("input[name='dd']")val();

那么我们可以给它新增一个事件监听,在datebox onSelect 日期选中后,自动为input id="dd" type=text赋值,然后我们就可以使用

$("#dd")val()获取选中的日期值了。

<script type=text/javascript>

$(document)ready(function(){

$("#dd")datebox({

required:true,

onSelect: function(date){

$("#dd")val(date);

}

});

});

</script>

3) javascript设定datebox的值

$("#dd")datebox("setValue", "2012-01-01");

例:新增编辑页面

@HtmlHidden("hBirthDate", ModelBirthDateToString("yyyy-MM-dd"))

$(document)ready(function () {

$("#BirthDate")datebox({

required: false,

formatter: function (date) { return dategetFullYear() + '-' + (dategetMonth() + 1) + '-' + dategetDate(); },

parser: function (date) { return new Date(Dateparse(datereplace(/-/g, "/"))); },

onSelect: function (date) {

$("#BirthDate")val(date);

}

});

处理日期格式问题

if ($("#hBirthDate")val() != "" && $("#hBirthDate")val() != "0001-01-01") {

$("#BirthDate")datebox("setValue", $("#hBirthDate")val());

} else {

$("#BirthDate")datebox("setValue", ((new Date())getFullYear() - 25) + "-01-01");

}

});

easy ui easyui-timespinner 时间控制元件 怎么取值

Easy UI的Datebox目前(版本15)不支援范围日期的选择及控制,要想实现,只能自己写JS或者后台逻辑进行判断及提示

怎么给easyui 时间控制元件赋值

1、 加入日期选择框“$("#dd")datebox({"required":true});”

2、 javascript获取日期选择框的值,“$("#dd")datebox("getValue");  或者$("input[name='dd']")val();”

3、给它新增事件监听,datebox onSelect 日期选中后,自动为input id="dd" type=text赋值,这样就可以使用“$("#dd")val()”获取选中的日期值了。

jQuery EasyUI是一组基于jQuery的UI外挂集合体,而jQuery EasyUI的目标就是帮助web开发者更轻松的打造出功能丰富并且美观的UI介面。开发者不需要编写复杂的javascript,也不需要对css样式有深入的了解,开发者需要了解的只有一些简单的标签。

如何获取时间控制元件里面选择的值

通常是这样做的,js控制元件选择一个日期后该控制元件的前面会有一个input框,该框的值就是你选定的值,然后再把form提交埃 另一种方法就是可以用ajax实现。

怎么获取h5时间控制元件的设定的时间

需要使用到CTime类,呼叫控制元件的SetTime函式设定时间,关于如何利用CTime类,可以参考MSDN联机说明

Html5时间控制元件datetime-local怎么在servlet获取值

需要自己手动去拼一个格式相同的时间,然后用 $("#id")val() 方法就可以直接设定的 时间格式:yyyy-MM-ddTHH:MM

js中如何获取easyui的日期控制元件的值

var v = $('#dd')datebox('getValue');

java 后台获取easyui控制元件的引数

通过 jquery 这样的AJAX,post到后台

~~~~~~~~

第一步,在web项目目录里创建静态页面tablehtml,并修改<title></title>标签内容,如下图所示:

第二步,在标题下方引入EasyUI相关的CSS和JS文件,如下图所示:

第三步,在body元素内部插入<table></table>,并引入表格样式以及数据源,如下图所示:

第四步,编辑表格数据源studentjson,设置表格需要的字段以及字段值

以上就是关于easyui 懂的进 我要设置easyui-datagrid 如何设置全部的内容,包括:easyui 懂的进 我要设置easyui-datagrid 如何设置、如图,用jquery easyui datagrid显示数据的,怎么让这两列标题隐藏。、EasyUI 结合JS导出Excel文件的实现方法等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9284488.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存