一个Form里常常会有好几个Tab,有时要根据一些条件设置哪些Tab可用,可见。下面就介绍下如何用JS对Tab进行控制。html
1. 控制可见web
function setTabVisableByName(tabName, flag) {
var control = Xrm.Page.ui.tabs.get(tabName);
control.setVisible(flag);}
这里flag是true或false学习
2. 控制可用ui
看了上面的可见代码,是否是觉得可用也这么简单呢?其实咱们把上面的setVisible改为setDisabled,会报错:spa
control.setDisabled is not a functiondebug
先看下Xrm.Page 的对象层次结构:orm
能够看到 tabs –> sections –> controls 这个层次结构。htm
因而就写了下面的代码:对象
function disableTab(tabName, flag) {
debugger;
var sections = Xrm.Page.ui.tabs.get(tabName).sections.get();
for (var j in sections) {var controls = sections[j].controls.get();
for (var i in controls) {var control = controls[i];
var controlType = control.getControlType();
if (controlType != "iframe" && controlType != "webresource" && controlType != "subgrid") {if (control != null && control.getDisabled() == !flag) {control.setDisabled(flag);}}}}}
其中有一行是判断control的类型:blog
if (controlType != "iframe" && controlType != "webresource" && controlType != "subgrid") {
这行代码是后来加上的,由于当时出现了一个很奇怪的现象,新建或查看记录时,没问题,但新建保存时老是会报这个错误:
control.setDisabled is not a function
加上这行后就ok了,这个问题当时花了我好长时间。
若是是要把整个form都禁用呢,能够用下面的代码,更简洁:
Xrm.Page.ui.controls.forEach(function (control, index) {
var controlType = control.getControlType();
if (controlType != "iframe" && controlType != "webresource" && controlType != "subgrid")) {control.setDisabled(flag);}});