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 ...
随机推荐
- js多张图片合成一张图,canvas(海报图,将二维码和背景图合并) -----vue
思路:vue中图片合并 首先准备好要合并的背景图,和请求后得到的二维码, canvas画图,将两张背景图和一张二维码用canvas画出来, 将canvas再转为img 注意canvas和图片的清晰图和 ...
- Sqlserver 2012附加数据库时出错提示操作系统错误5(拒绝访问)错误5120的解决办法
环境: Win10系统 SQLSERver 2012 情况: 使用混合登陆方式,sa账户密码正确登陆后,附加.mdf文件出现此错误. 尝试解决方法一:使用管理员运行SQLSERver2012,sa账户 ...
- idea运行时 Process finished with exit code -1073741819 (0xC0000005)
问题描述: idea中启动项目报 Process finished with exit code -1073741819 (0xC0000005) ,如图所示: 问题解决: ...
- Appium+Python之获取toast
思考:手机APP上的必填或错误文本提示一般1-2s就会消失,比较难定位,所以一般的固定元素定位方式是不可用的,那我们如何定位toast呢? 前提:1.Appium1.6.3以上(包括1.6.3) 2. ...
- python基础预习小结
一.执行python程序的两种方式 1.1 交互式 在终端内输入python3,然后输入python代码 1.2 命令式 在终端内输入python3文本文件路径 二.执行python的两种IDE 2. ...
- python一行代码打印Love心形
用Python画一颗特别的爱心,送给那个特别的她,给她一份浪漫的惊喜吧 print('\n'.join([''.join([('Love'[(x-y) % len('Love')] if ((x*0. ...
- Jade学习(六)之使用html2jade反编译
我们可以使用html2jade将html编译成jade 首先安装html2jade npm install html2jade -g 用法一:使用html2jade将html转为jade html2j ...
- PhpStorm 2017.3-2018.2 汉化包
JetBrains 系列软件汉化包 关键字: Android Studio 3.0-3.1.3 汉化包 CLion 2018.1-2018.2 汉化包 GoLand 2017.3.2-2018.2 汉 ...
- 在springboot中集成mybatis开发
在springboot中利用mybatis框架进行开发需要集成mybatis才能进行开发,那么如何在springboot中集成mybatis呢?按照以下几个步骤就可以实现springboot集成myb ...
- HTTPS加密原理与过程
HTTPS加密原理与过程 HTTP 超文本传输协议一种属于应用层的协议 缺点: 通信使用明文(不加密),内容可能会被窃听 不验证通信方的身份,因此有可能遭遇伪装 无法证明报文的完整性,所以有可能已遭篡 ...