Devexpress MVC DropDownList (持续更新))
@Html.DevExpress().DropDownEdit(settings =>
{
settings.Name = "psBankCharge";
settings.ControlStyle.Border.BorderColor = System.Drawing.Color.LightGray;
settings.Width = System.Web.UI.WebControls.Unit.Percentage(100);
settings.Height = System.Web.UI.WebControls.Unit.Pixel(34);
settings.ControlStyle.CssClass = "form-control dx-dropdown";
settings.Properties.NullText = @Utils.GetTranslation("Select") + " " + @Utils.GetTranslation("Bank Charge");
settings.Properties.NullTextStyle.CssClass = ":-moz-placeholder";
settings.Properties.DropDownWindowStyle.BackColor = System.Drawing.Color.FromArgb(0xEDEDED); settings.SetDropDownWindowTemplateContent(c =>
{
@Html.DevExpress().ListBox(
listBoxSettings =>
{
listBoxSettings.Name = "lbBankCharge";
listBoxSettings.ControlStyle.Border.BorderWidth = 0;
listBoxSettings.ControlStyle.BorderBottom.BorderWidth = 1;
listBoxSettings.ControlStyle.Border.BorderColor = System.Drawing.Color.LightGray;
listBoxSettings.ControlStyle.BorderBottom.BorderColor = System.Drawing.Color.FromArgb(0xDCDCDC);
listBoxSettings.Height = System.Web.UI.WebControls.Unit.Pixel(200);
listBoxSettings.Width = System.Web.UI.WebControls.Unit.Percentage(99.99);
listBoxSettings.Properties.SelectionMode = ListEditSelectionMode.CheckColumn;
listBoxSettings.Properties.ClientSideEvents.SelectedIndexChanged = "function(s, e){ ListBoxMultipleSelectionChanged(psBankCharge, s, e);}";
listBoxSettings.Properties.ValueType = typeof(string);
listBoxSettings.Properties.Items.Add("(Select all)");
foreach (ListEditItem item in (System.Collections.IEnumerable)ViewData["BankCharge"])
{
listBoxSettings.Properties.Items.Add(item.Text, item.Value);
}
}
).Render();
ViewContext.Writer.Write("<div style=\"margin: 6px; overflow hidden;\">");
@Html.DevExpress().Button(
buttonSettings =>
{
buttonSettings.Name = "btnCloseBankCharge";
buttonSettings.Text = "Close";
buttonSettings.ControlStyle.CssClass = "btn btn-default";
buttonSettings.ClientSideEvents.Click = "function(s, e){ psBankCharge.HideDropDown(); }";
}
).Render();
ViewContext.Writer.Write("</div>");
}); settings.DisabledStyle.BackColor = System.Drawing.Color.FromArgb(0xEEEEEE);
settings.Properties.AnimationType = DevExpress.Web.AnimationType.None;
settings.Properties.ClientSideEvents.TextChanged = "function(s, e){ SynchronizeListBoxMultipleValues(s, lbBankCharge); }";
settings.Properties.ClientSideEvents.DropDown = "function(s, e){ SynchronizeListBoxMultipleValues(s, lbBankCharge); }";
}).GetHtml()
//选中指定的Item,
SelectItemByValue(cboModalDepCode,lboModalDepCode,Value);
全部取消选中(多选)
ResetListBox(cboSearchDepCode, lboSearchDepCode);
全部取消选中(单选)
ResetSingleListBox(cboSearchDateOption,lboSearchDateOption);
获取选中的值(单选)
GetValuesByTexts(GetSelectedItemsText_Single(lboModalPackType.GetSelectedItems()), lboModalPackType);
获取选中的值(多选)
GetValuesByTexts(GetSelectedItemsText(lbBraCode.GetSelectedItems()).split(gs_TextSeparator),lbBraCode)
var gs_TextSeparator = ","; function UpdateSelectAllItemState(ao_lbListBox) {
IsAllSelected(ao_lbListBox) ? ao_lbListBox.SelectIndices([0]) : ao_lbListBox.UnselectIndices([0]);
} function IsAllSelected(ao_lbListBox) {
for (var i = 1; i < ao_lbListBox.GetItemCount() ; i++)
if (!ao_lbListBox.GetItem(i).selected)
return false;
return true;
} function UpdateText(ao_lbListBox, ao_ddlDropDown, ab_IsSingle) {
if (ab_IsSingle)
ao_ddlDropDown.SetText(GetSelectedItemsText_Single(ao_lbListBox.GetSelectedItems()));
else
ao_ddlDropDown.SetText(GetSelectedItemsText(ao_lbListBox.GetSelectedItems()));
} function GetSelectedItemsText(aa_Items) {
var la_Texts = [];
for (var i = 0; i < aa_Items.length; i++)
if (aa_Items[i].index != 0)
la_Texts.push(aa_Items[i].text);
return la_Texts.join(gs_TextSeparator);
} function GetSelectedItemsText_Single(aa_Items) {
var la_Texts = [];
for (var i = 0; i < aa_Items.length; i++)
la_Texts.push(aa_Items[i].text);
return la_Texts;
} function GetValuesByTexts(aa_Text, ao_lbListBox) {
var la_ActualTexts = [];
var ls_Item;
for (var i = 0; i < aa_Text.length; i++) {
ls_Item = ao_lbListBox.FindItemByText(aa_Text[i]);
if (ls_Item != null) {
la_ActualTexts.push( ls_Item.value );
} else {
la_ActualTexts.push("");
}
}
return la_ActualTexts;
}
function GetQuotesValuesByTexts(aa_Text, ao_lbListBox,as_Quotes) {
var la_ActualTexts = [];
var ls_Item;
for (var i = 0; i < aa_Text.length; i++) {
ls_Item = ao_lbListBox.FindItemByText(aa_Text[i]);
if (ls_Item != null) {
la_ActualTexts.push(as_Quotes + ls_Item.value + as_Quotes);
} else {
la_ActualTexts.push("");
}
}
return la_ActualTexts;
} function GetTextsByValues(aa_Value, ao_lbListBox) {
var la_ActualTexts = [];
var ls_Item;
for (var i = 0; i < aa_Value.length; i++) {
ls_Item = ao_lbListBox.FindItemByValue(aa_Value[i]);
if (ls_Item !== null)
la_ActualTexts.push(ls_Item.text);
}
return la_ActualTexts;
} function SelectItemByValue(ao_ddlDropDown, ao_lbListBox, as_Value) {
for (var i = 0; i < ao_lbListBox.GetItemCount() ; i++) {
if (ao_lbListBox.GetItem(i).value == as_Value) {
ao_lbListBox.SetSelectedIndex(i);
break;
}
}
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
} function SetSelectItemByText(ao_ddlDropDown, ao_lbListBox, as_Text) {
for (var i = 0; i < ao_lbListBox.GetItemCount() ; i++) {
if (ao_lbListBox.GetItem(i).text == as_Text) {
ao_lbListBox.SetSelectedIndex(i);
break;
}
}
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
} function SynchronizeListBoxValues(ao_ddlDropDown, ao_lbListBox) {
var la_Texts = ao_ddlDropDown.GetText().split(gs_TextSeparator);
var la_Values = GetValuesByTexts(la_Texts, ao_lbListBox);
ao_lbListBox.SelectValues(la_Values);
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
} function ListBoxSelectionChanged(ao_ddlDropDown, ao_lbListBox) {
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
ao_ddlDropDown.HideDropDown();
} function InitDropDown(ao_ddlDropDown, ao_lbListBox) {
ao_lbListBox.SetSelectedIndex(0);
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
} function ListBoxMultipleSelectionChanged(ao_ddlDropDown, ao_lbListBox, ao_lbListBoxEvent) {
if (ao_lbListBoxEvent.index === 0)
ao_lbListBoxEvent.isSelected ? ao_lbListBox.SelectAll() : ao_lbListBox.UnselectAll();
UpdateSelectAllItemState(ao_lbListBox);
UpdateText(ao_lbListBox, ao_ddlDropDown, false);
} function SynchronizeListBoxMultipleValues(ao_ddlDropDown, ao_lbListBox) {
ao_lbListBox.UnselectAll();
var la_Texts = ao_ddlDropDown.GetText().split(gs_TextSeparator);
var la_Values = GetValuesByTexts(la_Texts, ao_lbListBox);
ao_lbListBox.SelectValues(la_Values);
UpdateSelectAllItemState(ao_lbListBox);
UpdateText(ao_lbListBox, ao_ddlDropDown, false);
} function ResetListBox(ao_ddlDropDown, ao_lbListBox) {
ao_lbListBox.UnselectAll();
ao_ddlDropDown.SetText(null);
} function ResetSingleListBox(ao_ddlDropDown, ao_lbListBox) {
ao_lbListBox.SetSelectedIndex(0);
UpdateText(ao_lbListBox, ao_ddlDropDown, true);
}
Devexpress MVC DropDownList (持续更新))的更多相关文章
- MVC设计模式(持续更新中)
MVC设计模式--->英文全称为: model(模型) View (视图) Controller(控制) MVC是一种设计思想.这种思想强调实现模型(Model).视图(View)和控制 ...
- 蒋金楠How ASP.NET MVC Works?[持续更新中…]
一.ASP.NET + MVC IIS与ASP.NET管道 MVC.MVP以及Model2[上篇] MVC.MVP以及Model2[下篇] ASP.NET MVC是如何运行的[1]: 建立在“伪”M ...
- ASP.NET MVC 5 系列 学习笔记 目录 (持续更新...)
前言: 记得当初培训的时候,学习的还是ASP.NET,现在回想一下,图片水印.统计人数.过滤器....HttpHandler是多么的经典! 不过后来接触到了MVC,便立马爱上了它.Model-View ...
- 关于ASP.NET MVC开发设计中出现的问题与解决方案汇总 【持续更新】
最近一直用ASP.NET MVC 4.0 +LINQ TO SQL来开发设计公司内部多个业务系统网站,在这其中发现了一些问题,也花了不少时间来查找相关资料或请教高人,最终都还算解决了,现在我将这些问题 ...
- ASP.NET MVC深入浅出系列(持续更新) ORM系列之Entity FrameWork详解(持续更新) 第十六节:语法总结(3)(C#6.0和C#7.0新语法) 第三节:深度剖析各类数据结构(Array、List、Queue、Stack)及线程安全问题和yeild关键字 各种通讯连接方式 设计模式篇 第十二节: 总结Quartz.Net几种部署模式(IIS、Exe、服务部署【借
ASP.NET MVC深入浅出系列(持续更新) 一. ASP.NET体系 从事.Net开发以来,最先接触的Web开发框架是Asp.Net WebForm,该框架高度封装,为了隐藏Http的无状态模 ...
- ( 译、持续更新 ) JavaScript 上分小技巧(一)
感谢好友破狼提供的这篇好文章,也感谢写这些知识点的作者们和将他们整理到一起的作者.这是github上的一篇文章,在这里本兽也就只做翻译,由于本兽英语水平和编程能力都不咋地,如有不好的地方也请多理解体谅 ...
- [渣译文] 使用 MVC 5 的 EF6 Code First 入门 系列:为ASP.NET MVC应用程序更新相关数据
这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译,这里是第八篇:为ASP.NET MVC应用程序 ...
- ASP.NET MVC应用程序更新相关数据
为ASP.NET MVC应用程序更新相关数据 这是微软官方教程Getting Started with Entity Framework 6 Code First using MVC 5 系列的翻译, ...
- 【 js 基础 】【 源码学习 】源码设计 (持续更新)
学习源码,除了学习对一些方法的更加聪明的代码实现,同时也要学习源码的设计,把握整体的架构.(推荐对源码有一定熟悉了之后,再看这篇文章) 目录结构:第一部分:zepto 设计分析第二部分:undersc ...
随机推荐
- Linux集群之间配置NTP时间同步ntp
NTP时间同步 注意事项 要注意的是,ntpd 有一个自我保护设置: 如果本机与上源时间相差太大, ntpd 不运行. 所以新设置的时间服务器一定要先 ntpdate 从上源取得时间初值, 然后启动 ...
- python中迭代器和生成器。
前言:很多python教程中,对python的解释不容易理解,本文记录自己的理解和体会,是对迭代器和生成器的初步理解. 迭代器: 迭代器的实质是实现了next()方法的对象,常见的元组.列表.字典都是 ...
- transition 带的参数什么意思
过渡transition:属性名 过渡效果时间 时间速度曲线 开始时间 默认值: all 0 e ...
- Python中的四种数据结构
Python中的内置数据结构(Built-in Data Structure):列表list.元组tuple.字典dict.集合set,涵盖的仅有部分重点. 目录: 一.列表list 二.元组tup ...
- 优雅的用两种方式爬网络 txt 文件【雾
TXT 文件?? (笑 这里爬的是 74xsw (咱好像也不怎么逛的网站)的英雄再临 ... 请注意这并不是教程,只是贴个代码仅供参考而已[雾 这里 用的 getTXT 的方式有两种,一种是每个章节分 ...
- ajax跨域jsonp —— javascript
目录 jsonp是什么 jsonp原理 原生js使用jsonp jquery使用jsonp jsonp是什么 jsonp作用:解决跨域问题 为什么有跨域问题? “同源策略限制了从同一个源加载的文档或脚 ...
- VMware 中的win7虚拟机在一段时间后就会自动挂起
VMware workstation 中的win7虚拟机在一段时间不用后就会自动挂起. 其实这不是VMware workstation 的问题,而是win7的问题.关闭win7系统 的自动休眠功能即可 ...
- 2019-11-29-Roslyn-通过-Nuget-管理公司配置
title author date CreateTime categories Roslyn 通过 Nuget 管理公司配置 lindexi 2019-11-29 08:58:52 +0800 201 ...
- laravel查询数据库获取结果如何判断是否为空?
laravel 查询数据库获取结果如何判断是否为空? 大家使用的场景是这样的: 1 $users = DB::table('users')->where('id',$id)->get(); ...
- Librepilot-Spark2固件的烧写
1.通过USB连接Librepilot_Spark2飞控,启动Librepilot GCS地面站(博主的GCS是16.09版本),界面如下. 2.点击Firmware标签页,点击终止系统(若板子未带系 ...