在Asp.Net中使用JQueryEasyUI(转载)

下载引用
下载后解压的文件目录如下图:

demo:JQueryEasyUI的一些示例页面,在项目使用可以将该目录删除;
locale:该目录中是一些本地化文件,用来支持不同的语言,如中文可以引用其中的easyui-lang-zh_CN.js;
plugins和src:这两个目录中是支持JQueryEasyUI各种功能的js文件;
themes:主题目录,目录中有三种主题,default、gray和metro,另外还有一个icons目录和icon.css,在页面使用引用icon.css即可。
使用JQueryEasyUI需要引用四个文件,两个css和两个js文件:
<link rel="stylesheet" type="text/css" href="../Scripts/jqueryeasyui/themes/gray/easyui.css" />
<link rel="stylesheet" type="text/css" href="../Scripts/jqueryeasyui/themes/icon.css" />
<script type="text/javascript" src="../Scripts/jqueryeasyui/jquery-1.8.0.min.js"></script>
<script type="text/javascript" src="../Scripts/jqueryeasyui/jquery.easyui.min.js"></script>
如果需要使用本地化 还需要引用:
<script type="text/javascript" src="../Scripts/jqueryeasyui/locale/easyui-lang-zh_CN.js"></script>
JQueryEasyUI Grid的分页
根据官网的文档可以很容易的构建Grid,期初我没有引用本地化文件easyui-lang-zh_CN.js,列表的分页栏显示出来是英文的,在网上查阅后得知可以用代码的方式重新构建分页栏:
//设置分页控件  var p = $(‘#dg‘).datagrid(‘getPager‘);
$(p).pagination({
    pageSize: 10, //每页显示的记录条数,默认为10  pageList: [10, 20, 30, 40, 50], //可以设置每页记录条数的列表  beforePageText: ‘第‘, //页数文本框前显示的汉字
    afterPageText: ‘页    共 {pages} 页‘,
    displayMsg: ‘当前显示 {from} - {to} 条记录 共 {total} 条记录‘
    /*onBeforeRefresh:function(){              $(this).pagination(‘loading‘);              alert(‘before refresh‘);              $(this).pagination(‘loaded‘);          }*/
});
后来发现只需要引用本地化文件easyui-lang-zh_CN.js后分页栏就自动显示为中文了。引用本地化文件还可以解决日历控件格式的问题,所以如果是做中文系统建议还是在页面中引用本地化文件。
JQueryEasyUI控件的取值
使用JQuery取控件的值很简单,如下:
$("#CstName").val();
$("#TaskNo").val(),
如果要使用JQueryEasyUI的日历控件、下拉控件或其他的一些控件,给普通的input、select控件添加一个class即可:
<input id="FeedBackDate" name="FeedBackDate" class="easyui-datebox" maxlength="10"
 style="width: 150px;" />
<select id="IsKfCl" class="easyui-combobox" name="IsKfCl" style="width:150px;">
    <option value=""></option>  
    <option value="是">是</option> 
    <option value="否">否</option> 
</select>
现在取这些控件的值需要使用下面的方法:
$("#FeedBackDate").datebox("getValue");
$("#IsKfCl").combobox("getValue");
Grid ToolBar的两种方式
通常在Grid列表控件的上方会添加一些按钮如:新增、编辑、删除等,如下面效果:

在JQueryEasyUI中可以使用ToolBar来实现,ToolBar可以在DataGrid初始化时定义,如下:
$(‘#dg‘).datagrid({
    collapsible: false,
    fitColumns: true,
    singleSelect: true,
    remoteSort: false,
    sortName: ‘RoleName‘,
    sortOrder: ‘desc‘,
    nowrap: true,
    method: ‘get‘,
    loadMsg: ‘正在加载数据...‘,
    url: ‘...‘,
    frozenColumns: [[
        { field: ‘ck‘, checkbox: true }
    ]],
    columns: [[
        { field: ‘ID‘, title: ‘ID‘,  80, sortable: true },
        { field: ‘Name‘, title: ‘名称‘,  100,sortable:true }
    ]],
    pagination: true,
    pageNumber: 1,
    rownumbers: true,
    toolbar:
    [
        {
            id: ‘btnAdd‘,
            text: ‘添加‘,
            iconCls: ‘icon-add‘,
            handler: function() {
                $("#name").val("");
                add();
            }
        },
        ‘-‘,
        {
            id: ‘btnEdit‘,
            text: ‘编辑‘,
            iconCls: ‘icon-edit‘,
            handler: function() {
                var selected = $(‘#dg‘).datagrid(‘getSelected‘);
                if (selected) {
                    var name = selected.Name;
                    $("#Name").val(name);
                    edit();
                }
            }
        },
        ‘-‘,
        {
            id: ‘btnDelete‘,
            text: ‘删除‘,
            disabled: true,
            iconCls: ‘icon-remove‘,
            handler: function() {
            }
        }
    ]
});
        });
还有一种方法就是将ToolBar单独定义在div中,然后在DataGrid的初始化时关联div的ID,首先定义ToolBar的div,ID为tb:
<!--工具栏-->
<div id="tb" style="padding: 5px; height: auto;display:none;">
    <div style="margin-bottom: 5px">
        <a href="#" class="easyui-linkbutton" iconcls="icon-add" onclick="add()">新增</a>
        <a href="#" class="easyui-linkbutton" iconcls="icon-edit" onclick="edit()">编辑-</a>
        <a href="#" class="easyui-linkbutton" iconcls="icon-edit" onclick="copyAdd()">拷贝′</a>
        <a href="#" class="easyui-linkbutton" iconcls="icon-cut" onclick="copyVss()">复制地址·</a>
        <a href="#" class="easyui-linkbutton" iconcls="icon-save" onclick="downReg()">下载REG</a>
        <a href="#" class="easyui-linkbutton" iconcls="icon-remove" onclick="del()">删除y</a>
        <!--查询区域-->
        区域:<input id="seaArea" style="width: 100px" />
        客户名称:<input id="seaCstName" style="width: 100px" />
        <a href="#" class="easyui-linkbutton" iconcls="icon-search" onclick="searchSrcCode()">查询</a>
    </div>
</div>
在DataGrid的初始化时设置toobar属性值为tb:
pagination: true,
pageNumber: 1,
rownumbers: true,
toolbar: ‘#tb‘,
...
单独定义ToolBar个人认为要灵活些,也会让JS代码简洁些。
Form表单的提交
上面说过了列表的显示,下面就来讲下数据的提交,有两种方式可以实现:
自己组织数据然后用Ajax(GET POST)提交;
使用Form表单提交的方式。
我在刚使用的时候是使用的第一种方法:
//保存
function saveFeedBackLog(mode,id) {
    $.ajax({
        type: "POST",
        dataType: "json",
        //cache:true,
        url: "../Ajax/FeedBackLogAjax.ashx?Method=SaveFeedBackLog",
        data: { FeedBackDate: $("#FeedBackDate").datebox("getValue"),
            CstName: $("#CstName").val(),
            TaskNo: $("#TaskNo").val(),
            FeedBackContent: $("#FeedBackContent").val(),
            CsZrr: $("#CsZrr").combobox("getValue"),
            CsYzResult: $("#CsYzResult").val(),
            IsKfCl: ,
            KfZrr: $("#KfZrr").combobox("getValue"),
            EndDate: $("#EndDate").datebox("getValue"),
            KfClDate: $("#KfClDate").val(),
            Wtyy: $("#Wtyy").val(),
            Mode:mode,
            ID:id
        },
        success: function (data) {
        //..........
当页面字段比较多的时候会比较麻烦,保存时需要将每个字段的值逐一取出传送到后台,编辑时也需要将行中各字段的值逐一取出赋给表单中的控件,后来发现JQueryEasyUI提供Form的Ajax提交的方式,会使代码精简很多,而且使用Form表单提交的方式还能用到JQueryEasyUI提供的一些验证控件。
编辑时赋值给表单
function edit() {
    var rowData = $(‘#dg‘).datagrid(‘getSelections‘);
    if (rowData.length == 0) {
        $.messager.alert(‘提示‘, ‘请选择要编辑的项!‘,‘info‘);
    }
    else if (rowData.length > 1) {
        $.messager.alert(‘提示‘, ‘只能选择一项进行编辑!‘,‘info‘);
    }
    else {
        _mode = "2";
        var row = $(‘#dg‘).datagrid(‘getSelected‘);
        openDialog();
        $(‘#fm‘).form(‘load‘, row);
        _srcCodeManageID = row.SrcCodeManageID;
        url = "../Ajax/SrcCodeManageAjax.ashx?Method=SaveSrcCodeManage&ID=" + row.SrcCodeManageID+"&Mode="+_mode;
    }
}
保存
//保存
function saveSrc() {
    $(‘#fm‘).form(‘submit‘, {
        url: url,
        onSubmit: function () {
            return $(this).form(‘validate‘);
        },
        success: function (data) {
            if (data =="Success") {
                $(‘#dlg‘).dialog(‘close‘);      // close the dialog 
                $(‘#dg‘).datagrid(‘reload‘);    // reload the user data 
                $.messager.alert(‘提示‘, ‘保存成功!‘, ‘info‘);
            }
            else if (data=="Error")
            {
                $.messager.alert(‘错误‘, ‘系统出错!‘, ‘error‘);
            }
        }
    }); 
}
可以看出第二种方法相比第一种代码精简了很多,而且保存时还能用到表单的一些校验,比如设置必填项、电话、邮件格式等。
当然JQueryEasyUI还有很多其他的控件和功能,有待以后慢慢研究,希望本文对你有所帮助。

时间: 2024-10-12 07:17:43

在Asp.Net中使用JQueryEasyUI(转载)的相关文章

如何在Asp.Net中使用JQueryEasyUI

JQueryEasyUI的基本信息: 官方下载 官方演示 官方文档 一.jQuery easyUI下载后解压的文件目录如下图: demo:JQueryEasyUI的一些示例页面,在项目使用可以将该目录删除: locale:该目录中是一些本地化文件,用来支持不同的语言,如中文可以引用其中的easyui-lang-zh_CN.js: plugins和src:这两个目录中是支持JQueryEasyUI各种功能的js文件: themes:主题目录,目录中有三种主题,default.gray和metro,

[转载] asp.net中,&lt;%#%&gt;,&lt;%=%&gt;和&lt;%%&gt;分别是什么意思,有什么区别

在asp.net中经常出现包含这种形式<%%>的html代码,总的来说包含下面这样几种格式: 一. <%%> 这种格式实际上就是和asp的用法一样的,只是asp中里面是vbscript或者javascript代码,而在asp.net中是.net平台下支持的语言. 特别注意:服务器控件中不能有<%%>语法 (这里用C#代码) <% int a = 2; int b = 3; int c = a + b; Response.Write(c); %>二. <

asp.net中打开新窗口的多种方法(转载)

asp.net中打开新窗口的多种方法 1.Response.Redirect("XXX.aspx",true)——直接转向新的页面,原窗口被代替; 2. Response.Write("<script>window.open(XXX.aspx'',''_blank'')</script>")——原窗口保留,另外新增一个新页面; 3.Response.Write("<script>window.location=XXX.a

【转载】ASP.Net 中DataTextField和DataValueField

asp.net中DDL的DataTextField和DataValueFiled之间的区别和作用. 在asp.net中,绑定DropDownList控件时,会要求你绑定属性的值,因为一个数据源里可能有很多字段,DropDownList控件怎么会知道你想让数据源中的哪一个字段显示出来,哪一个字段作为值进行传递呢? DropDownList控件: DataTextField:将是绑定显示的字段,这个字段的值将会出现在下来框中. DataValueFiled:将是显示的字段所在的行对应的字段的值,作为

asp.net中怎样调用存储过程和存储过程的写法(转载,留着自己看)

asp.net中怎样调用存储过程和存储过程的写法 创建一个只有输入参数的存储过程 create procedure proc_user@name varchar(20),@Password varchar(100)as select * from loginuser where name like @name ---创建一个有输入和输出参数的存储过程 create procedure proc_usertext@name varchar(20),@blog varchar(100) output

asp.net中javascript与后台c#交互

asp.net中javascript与后台c#交互 作者:熊猫大叔 字体:[增加 减小] 类型:转载 时间:2015-10-23我要评论,出处:http://www.jb51.net/article/73793.htm 这篇文章主要介绍了asp.net中javascript与后台c#交互,需要的朋友可以参考下 最近做一个小项目,网页中嵌入google maps,输入经纬度坐标可以定位地图位置并加注标记,点击标记获取远端摄像头数据并在视频窗口实现播放.在实际操作过程中,由于经纬度数据和视频登录的用

Asp.net中动态控制RDLC报表 自定义RDLC

转载自: http://dlwang2002.cnblogs.com/archive/2006/05/27/410499.html 在asp.net程序中,可以选择使用水晶报表,功能确实强大.但是web版的水晶报表好像存在版权的问题.如果所作报表不是复杂的一塌糊涂的话,可以使用微软自带的Rdlc报表.已经有老兄做出了不少诠释:http://www.cnblogs.com/waxdoll/更多资料可以在这里找到:http://www.gotreportviewer.com/Rdlc优点:1:Rdl

3、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle项目开发之——用户登录

最近由于项目赶着上线,一直没时间接着写博客,今天终于空出了时间.声名:我不是专业美工,所以界面问题,希望大家不要拍砖.登录界面如下: 在ASP.NET MVC中,要新增一个功能,我们首先要添加一个控制器,AccountController.cs,添加方法:右键单击Controllers文件夹, /// <summary> /// 登录页面 /// </summary> /// <returns></returns> public ActionResult I

4、VS2010+ASP.NET MVC4+EF4+JqueryEasyUI+Oracle项目开发之——后台管理界面

这一章节比较简单,我就直接贴代码了,后台管理登陆界面如下: 对应的控制器HomeController.cs,代码如下: using YKT.Model; using YKT.Common; using YKT.BLL; using YKT.Common.HtmlHelpers; using YKT.Common.Functions; using Microsoft.Practices.Unity; using YKT.IBLL; namespace YKT.Controllers { publi