Dynamic CRM 2013學習筆記(十六)用JS控制Tab可見,可用


一個Form里經常會有好幾個Tab,有時要根據一些條件設置哪些Tab可用,可見。下面就介紹下如何用JS對Tab進行控制。

1. 控制可見

 

function setTabVisableByName(tabName, flag) {
    var control = Xrm.Page.ui.tabs.get(tabName);
    control.setVisible(flag);
}

這里flag是true或false

 

2. 控制可用

看了上面的可見代碼,是不是以為可用也這么簡單呢?其實我們把上面的setVisible改成setDisabled,會報錯:

control.setDisabled is not a function

 

先看下Xrm.Page 的對象層次結構:

image

可以看到 tabs –> sections –> controls 這個層次結構。

於是就寫了下面的代碼:

 

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的類型:

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);
        }
    });

Dynamic CRM 2013學習筆記 系列匯總


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM