转自 http://blog.csdn.net/dj2008/article/details/45313805

最近的项目里用到了Kendo UI。这货很好很强大,但可惜官方文档组织的并不是很好,有很多配置非常坑,需要自己去发掘。

一、版本

首先,是版本的区别。简单的来说,免费版的Kendo UI是不包含DataViz组件的,即没有图表功能,并且也没有服务端的Helper,比如MVC的wapper,所以,免费版只有js和css,不会给你dll的。

收费版,比如for MVC的这个版本,除了包含dataviz以外,还包含预先定义好的mvc wapper,所以你需要引用dll才能使用kendo的html helper。这些Helper的功能仅仅是生成对应的JS,对于熟悉C#的程序员来说,图个方便而已。不过不得不承认,这些helper的设计是一流的,使用lambda表达式来配置参数感觉非常棒。

总结一下,如果你的团队前端程序员非常碉,你可以使用免费版,但不包含图表组件。如果你是像我一样的屌丝ASP.NET猿,又为了快速开发应用,你就应该买收费版。999美元,卖个肾就有了。

二、和bootstrap 3.0的样式冲突问题

一开始我就发现kendo ui的最新版和bootstrap 3.0的样式有小冲突了,官方论坛里也说目前不支持。但是有个临时的解决办法,可以override一下bootstrap 3.0的CSS。不兼容的问题主要是因为box-sizing引起的:

/* kendo ui blow up hack with bootstrap 3.0 */

.k-widget,
.k-widget *,
.k-animation-container * {
-webkit-box-sizing: content-box;
-moz-box-sizing: content-box;
box-sizing: content-box;
} .k-window-titlebar.k-header {
-moz-box-sizing: content-box !important;
-webkit-box-sizing: content-box !important;
box-sizing: content-box !important;
} .k-window-title {
font-size: 12px;
}

这段CSS记的加在bootstrap的后面,浏览器才会更具优先级使用后面的CSS覆盖前面的。

三、Grid的数据绑定

如果你发现Grid数据绑不上,首先检查这些问题:

1. jQuery引用了没?如果引用了,那它的位置是在哪里?按照MVC4以后的默认模板,jquery是在页面尾部的,而kendo生成的js会渲染在jquery的上面,这样就爆掉了。所以建议把jquery单独拿到header里面。

2. kendo.aspnetmvc.min.js引用了没?这个JS是专门为了配合kendo在服务端的代码而用的,有了它,grid就可以传递POST请求而不是GET请求,并且后台才能正确的做model binding。

首先,如果是binding to remote data的话,kendo要求后台返回JSON字符串,所以你的action必须返回JsonResult。当然,方法签名可以是ActionResult,毕竟JsonResult is-a ActionResult。

另外,参数必须含有kendo自己的request参数:public ActionResult GetChannelGridData( [DataSourceRequest]DataSourceRequest request )。

最后,拿到数据后,必须用kendo的dll里对IQueryable的拓展方法去撸一遍,才能撸成kendo grid认识的JSON格式:

var grid = list.ToDataSourceResult(request);
return Json(grid);

4. 关于分页、排序、筛选的服务端操作

简单的说,如果你的数据源是IQueryable的,比如从EntityFramework里返回的,那kendo ui grid会自动帮你处理所有的服务端操作。不然的话,你就应该看看custom binding的文档:

http://docs.kendoui.com/getting-started/using-kendo-with/aspnet-mvc/helpers/grid/custom-binding

四、Grid的外键列

Grid的外键列可以在编辑模式里自动变成下拉列表,不过这是个大坑,光看官网demo你肯定是撸不出来的。

首先,在后台,你需要一个方法来返回这个下拉列表:

private void PopulateChannels()
{
var channels = db.Channel
.Select(c => new ChannelViewDataModel
{
ChannelId = c.Id,
Title = c.Title
})
.OrderBy(e => e.Title).ToList(); ViewData["channels"] = channels;
ViewData["defaultChannel"] = channels.FirstOrDefault();
}
public ActionResult Index()
{
PopulateChannels();
return View();
}

然后,Grid里,对外键列这样配置:

columns.ForeignKey(p => p.ChannelId, (IEnumerable

 )ViewData["channels"], "ChannelId", "Title").Title("渠道");

DataSource里这样配置:

.Model(model =>
{
model.Id(p => p.Id);
model.Field(p => p.Id).Editable(false);
model.Field(p => p.ChannelId).DefaultValue(((ChannelViewDataModel)ViewData["defaultChannel"]).ChannelId);
})

记的一定要配默认值,不然当下拉列表只有一个值的时候,是传不回后台的,这应该是个bug。

最后是个最最坑爹的,你需要一个EditorTemplate才能让它显示为下拉列表!!!

@using Kendo.Mvc.UI

@(Html.Kendo().DropDownListFor(m => m)
.DataValueField("ChannelId")
.DataTextField("Title")
.BindTo((System.Collections.IEnumerable)ViewData["channels"])
)

坑爹还在继续,有了这个template,你还得在model里写一笔UIHint:

public class ActivationDataGridModel
{
public Guid Id { get; set; } [UIHint("ChannelDropDown")]
public Guid? ChannelId { get; set; } [UIHint("NumericSelector")]
public int NumberOfActivation { get; set; } [UIHint("Date")]
public DateTime? PubDate { get; set; } public ActivationDataGridModel()
{
Id = Guid.NewGuid();
}
}

五、如何让Kendo Window只有在点击后才弹出,并且居中显示

据我研究,在MVC Wapper里是不能实现的。这里我们必须手写JS了。

首先,你需要一个承载窗体内容的DIV:<div id="chartwindow"></div>

然后,用jquery给你的按钮或链接注册一个点击事件:

$(function () {
$("#viewChart").click(function () {
if (null == currentSelectedChannelId) {
alert('请先选择一个渠道');
}
else {
console.info(currentSelectedChannelId); $("#chartwindow").kendoWindow({
"modal": true,
"iframe": true,
"draggable": true,
"pinned": false,
"title": "@ViewBag.SelectedProductTitle",
"resizable": true,
"content": "@Url.Content("~/ActivationData/GetChartImage?channelId=")" + currentSelectedChannelId,
"width": 720, "height": 480,
"actions": ["Refresh", "Maximize", "Close"]
}); $("#chartwindow").data("kendoWindow").open();
$("#chartwindow").data("kendoWindow").center();
}
});
})

居中显示的代码在最后一行,.center()方法。

六、折线图Line Chart自动步长

默认情况下,你很容易做出这样的chart:

但是你需要这样的chart:

.CategoryAxis(axis => axis
.Justify()
.Date().AutoBaseUnitSteps(a =>
{
a.Days(1);
a.Weeks(2);
a.Months(3);
})
.BaseUnitStep(0)
.Categories(model => model.PubDate.Value)
)

分别给你需要的场景,比如日、周、月设置默认步长后,再指定BaseUnitStep为0就好了,0就是自动的,默认是1,会爆的

Kendo UI for ASP.NET MVC 的一些使用经验(转)的更多相关文章

  1. Kendo UI For ASP.NET MVC项目资源

    一.官网: 1.Telerik大学官网:http://best.telerikacademy.com/ 二.相关博客 1.http://blog.csdn.net/magicsgxie/article ...

  2. UI控件Telerik UI for ASP.NET MVC全新发布R2 2019 SP1

    Telerik UI for ASP.NET MVC拥有使用JavaScript和HTML5构建网站和移动应用所需的70+UI部件,来满足开发者的各种需求,提供无语伦比的开发性能和用户体验.它主要是针 ...

  3. 下载文件时-修改文件名字 Redis在Windows中安装方法 SVN安装和使用(简单版) WinForm-SQL查询避免UI卡死 Asp.Net MVC Https设置

    下载文件时-修改文件名字   1后台代码 /// <summary> /// 文件下载2 /// </summary> /// <param name="Fil ...

  4. Kendo UI for jQuery使用教程——使用NPM/NuGet进行安装

    [Kendo UI for jQuery最新试用版下载] Kendo UI目前最新提供Kendo UI for jQuery.Kendo UI for Angular.Kendo UI Support ...

  5. 【Kendo UI系列开发使用笔记】01-简单介绍

    ps:接触telerik出品的kendo ui系列已经快有一年了,使用过程中也在不断踩坑填坑.这套UI用起来还是非常爽的,尤其asp.net mvc版的配合lambda表达式来配置参数非常流畅.这次对 ...

  6. Kendo UI for jQuery使用教程——创建自定义捆绑包

    [Kendo UI for jQuery最新试用版下载] Kendo UI目前最新提供Kendo UI for jQuery.Kendo UI for Angular.Kendo UI Support ...

  7. Kendo UI使用教程:入门指南

    [Kendo UI最新试用版下载] Kendo UI目前最新提供Kendo UI for jQuery.Kendo UI for Angular.Kendo UI Support for React和 ...

  8. 5、ASP.NET MVC入门到精通——NHibernate代码映射

    本系列目录:ASP.NET MVC4入门到精通系列目录汇总 上一篇NHibernate学习笔记—使用 NHibernate构建一个ASP.NET MVC应用程序 使用的是xml进行orm映射,那么这一 ...

  9. ASP.NET MVC 学习7、为Model Class的字段添加验证属性(validation attribuate)

    Adding Validation to the Model ,在Model中添加数据验证 参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-star ...

随机推荐

  1. 分布式任务分发框架Gearman教程和PHP实现实例

    1.Gearman介绍和使用场景 Gearman是一个分发任务的程序框架,可以用在各种场合,与Hadoop相 比,Gearman更偏向于任务分发功能.它的任务分布非常简单,简单得可以只需要用脚本即可完 ...

  2. [Tex学习笔记]开方

    $$\sqrt[n]{\frac{a}{b}}$$ $$\sqrt[\uproot{7}n]{\frac{a}{b}}$$

  3. java内存溢出分析(一)

    在项目中发现内存占用过高,且一直不会释放,top命令如下图显示 可以看到pid为17453的java进程占用27.1%内存,且长时间没有释放. 1.使用命令生成heap日志以供分析 sudo jmap ...

  4. Windows下PHP版本选取

    1. 下载地址 http://windows.php.net/download/ 2. PHP大版本 PHP4:由于太古老.对OO支持不力已基本被淘汰. PHP5:分为三个分支——PHP5.2之前的版 ...

  5. QQ粘性布局

    *:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...

  6. Flex加载google地图、百度地图以及天地图作底图

    一  Flex加载Google地图作底图 (1)帮助类GoogleLayer.as /* * 根据输入的地图类型加载Google地图(by chenyuming) */ package Layers ...

  7. Contos7 装bcm4312无线网卡驱动

    本次装网卡比较的无语,报错网上竟然找不到答案,误打误撞给装好了,做下记录以后可能会用的上. 首先去官网下载网卡驱动:http://www.broadcom.com/support/802.11 我系统 ...

  8. Servlet的异常处理

    Servlet 异常处理 当一个 Servlet 抛出一个异常时,Web 容器在使用了 exception-type 元素的 web.xml 中搜索与抛出异常类型相匹配的配置. 您必须在 web.xm ...

  9. 41. 这张表lbdeveloplog可以查看各个对象的提交情况,包括是哪个IP提交的

    lbdeveloplog 这张表lbdeveloplog可以查看各个对象的提交情况,包括是哪个IP提交的

  10. logging日志模块

    为什么要做日志: 审计跟踪:但错误发生时,你需要清除知道该如何处理,通过对日志跟踪,你可以获取该错误发生的具体环境,你需要确切知道什么是什么引起该错误,什么对该错误不会造成影响. 跟踪应用的警告和错误 ...