你们如何有条件地禁用 ASP 树视图中的复选框?
例如,如果应用程序用户没有特定权限,请禁用权限树视图中的该权限条目复选框。
这就是我正在寻找的内容,这是 winform 应用程序中的等效项(文本灰显的复选框被禁用):
我看到了其他解决方案,其中复选框上的单击事件被拦截并忽略。我更喜欢将复选框简单设置为禁用的解决方案。
我正在寻找 C# 解决方案,但对 C#/Javascript 解决方案感到满意。
Thanks!
好的,找到了一个相当干净的解决方案:
在代码隐藏中:
TreeNode newNode = new TreeNode(permission.ToString());
newNode.SelectAction = TreeNodeSelectAction.None; // no Link
if (shouldDisableCheckbox)
{
// Set a class so disabled nodes can be formatted thru CSS
// and be identifiable as disabled in Javascript.
newNode.Text = "<span class=disabledTreeviewNode>" + newNode.Text +"</span>";
}
nodes.Add (newNode);
在 Javascript 中,扫描所有树视图节点以查找具有该 className 的节点并禁用与它们关联的复选框:
// Called via a startup script created in Code Behind.
// Disables all treeview checkboxes that have a text with a class=disabledTreeviewNode.
// treeviewID is the ClientID of the treeView
function DisableCheckBoxes(treeviewID)
{
TREEVIEW_ID = treeviewID;
var treeView = document.getElementById(TREEVIEW_ID);
if (treeView)
{
var childCheckBoxes = treeView.getElementsByTagName("input");
for (var i = 0; i < childCheckBoxes.length; i++)
{
var textSpan = GetCheckBoxTextSpan(childCheckBoxes[i]);
if (textSpan.firstChild)
if (textSpan.firstChild.className == "disabledTreeviewNode")
childCheckBoxes[i].disabled = true;
}
}
}
function GetCheckBoxTextSpan(checkBox)
{
// Set label text to node name
var parentDiv = checkBox.parentNode;
var nodeSpan = parentDiv.getElementsByTagName("span");
return nodeSpan[0];
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)