powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Oracle APEX [игнор отключен] [закрыт для гостей] / Доступ к атрибутам плагина из javascript
25 сообщений из 42, страница 1 из 2
Доступ к атрибутам плагина из javascript
    #38880235
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Здравствуйте.

Пишу простенький dynamic action плагин.
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators';
return render_result;
end;



Первый атрибут - список итемов для проверки.
Второй атрибут - список кнопок, которые надо лочить, если хоть один из итемов пустой.

Файл validator.js:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
function reset() {
	var items = init_validators.prototype.action.attribute01.split(',');
	var buttons = init_validators.prototype.action.attribute02.split(',');
}

function init_validators() {
	var items = this.action.attribute01.split(',');
	var buttons = this.action.attribute02.split(',');
}



Функция init_validators определена как точка входа в pl/sql коде плагина и внутри нее доступ к атрибутам осуществляется через this.action.
А внутри функции reset получить доступ к этим атрибутам уже нельзя. пробовал решить это через глобальные переменные, но этот способ не подходит потому что если подключать плагин более одного раза на страницу то эти переменные затираются последующими вызовами. Какой подход поможет в данной ситуации?
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880484
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89,

Тут очень простой выход.
Внутри функции init_validators(), создай объект, из из любой другой обращайся к нему.

Код: javascript
1.
2.
3.
4.
var myObj = {
	items : this.action.attribute01.split(','),
	buttons : this.action.attribute02.split(',')
};



Обращение к объекту
Код: javascript
1.
myObj.items;



Ну это ближе к Яваскрипту уже.
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880502
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
blkangel,

Ах да, и функцию ресет внутри объекта надо разместить, тогда путаницы не будет.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
var myObj = {
	items : this.action.attribute01.split(','),
	buttons : this.action.attribute02.split(','),
	reset : function () {
		var me=this;
		console.log(me.items);
		console.log(me.buttons);
	}
};
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880530
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
blkangel,

И еще, для того чтобы объекты не пересекались.
Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators("'||to_char(p_dynamic_action.id)||'")';
return render_result;
end;




Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
function init_validators(aId) {
	var myObj={};
	var myObj[aId] = {
		items : this.action.attribute01.split(','),
		buttons : this.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880578
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function set_validators(dynamic_action_id) {
    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
}



а еще должна быть отдельная функция reset_interface, которая бы убирала у полей сообщения об ошибках и сбрасывала цвет в обычный. у меня до этого приходилось на странице вызывать ее так: reset_interface( ['P50_X1', 'P50_X2'], ['P50_B1', 'P50_B2'] ) и это работало. но хотелось бы чтобы эта функция имела доступ к атрибутам плагина и вызов был reset_interface(). правда тут еще проблема определить, к какому плагину соответствует этот вызов
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880701
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:

Виноват, так конечно:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
function init_validators(aId) {
	var meFun=this;
	var myObj={};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880702
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
blkangelDiagnost89blkangel,

при построении объекта происходит вот такая ошибка:
Uncaught TypeError: Cannot read property 'attribute01' of undefined

видимо потому что this уже не к контексту функции set_validators обращается, а к контексту объекта

да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:

Виноват, так конечно:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
function init_validators(aId) {
	var meFun=this;
	var myObj={};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};


Еще чутка исправления.
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
function init_validators(aId) {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[aId] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		}
	};
};
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880712
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89blkangel,
да и получить доступ потом извне никак. смысл в том что есть функция set_validators. она соответствующим полям привязывала обработчики их изменения:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function set_validators(dynamic_action_id) {
    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
}



а еще должна быть отдельная функция reset_interface, которая бы убирала у полей сообщения об ошибках и сбрасывала цвет в обычный. у меня до этого приходилось на странице вызывать ее так: reset_interface( ['P50_X1', 'P50_X2'], ['P50_B1', 'P50_B2'] ) и это работало. но хотелось бы чтобы эта функция имела доступ к атрибутам плагина и вызов был reset_interface(). правда тут еще проблема определить, к какому плагину соответствует этот вызов

А тут давай подробно разбирать...
1. Раз ты делаешь плагин, он должен быть независим, и не требовать дописок яваскрипта на страницах.
2. Предположим, что ты делаешь API для своего плагина, и тебе надо все таки из вне вызывать функцию. Загвоздка в том, что dynamic_action_id ты никогда не вычислишь из вне, но тут напрашивается вывод сам собой, ты должен третьим атрибутом передавать название объекта. И получится примерно так.
pl/sql упростится

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
function render (
    p_dynamic_action in apex_plugin.t_dynamic_action,
    p_plugin         in apex_plugin.t_plugin )
    return apex_plugin.t_dynamic_action_render_result
is
render_result apex_plugin.t_dynamic_action_render_result default null;
begin
apex_javascript.add_library(
	p_name => 'validator',
    p_directory => p_plugin.file_prefix,
    p_version => null
);
render_result.attribute_01 := p_dynamic_action.attribute_01;
render_result.attribute_02 := p_dynamic_action.attribute_02;
render_result.javascript_function := 'init_validators()';
return render_result;
end;



javascript :
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function init_validators() {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[meFun.action.attribute03] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		},
		setValidation : function () {
			var me=this;
			for (var i in me.items) {	
				var f = me.validator(me.items[i], me.items, me.inputs);
			}
		},
		validator : function(item_id, items, inputs) {
			....
		}
	};
};



Вызов функций внутри объекта, так.
Код: javascript
1.
myObj.attribute03.reset();
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880753
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
В данный момент остановился на таком варианте:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
89.
90.
91.
92.
93.
94.
95.
96.
97.
98.
99.
100.
101.
102.
103.
104.
105.
106.
107.
108.
109.
110.
111.
112.
113.
114.
115.
116.
117.
118.
119.
120.
121.
122.
function disable_input(id) {
    $('#'+id).prop('disabled', 'disabled');
}

function enable_input(id) {
    $('#'+id).removeAttr('disabled');
}

function set_valid_colors(item_id) {
    $('label[for='+item_id+']>span,label[for='+item_id+']>a').css('color', '#444');
    $('#'+item_id).css('border', '1px solid rgb(170,170,170)');
}

function set_error_colors(item_id) {
    $('label[for='+item_id+']>span,label[for='+item_id+']>a').css('color', '#b94a48');
    $('#'+item_id).css('border', '1px solid #b94a48');
}

function item_is_empty(item_id) {
    return $('#'+item_id).val() == '';
}

function show_tooltip(item_id, message) {
    var td = $('#'+item_id).parent('td');
    $(td).css('position', 'relative');
    $('<div class="tooltip-container"><span class="tooltip-message">'+message+'</span></div>').appendTo(td);
}

function hide_tooltip(item_id) {
    var td = $('#'+item_id).parent('td');
    $(td).find('.tooltip-container').remove();
}

var production_mode = true;

function reset_interface(form_id) {
    var with_errors = false;
    var item_arr = $('#' + form_id + ' .not_empty_item');
    var input_arr = $('#' + form_id + ' .not_empty_button');
    for (var i in item_arr) {
        set_valid_colors(item_arr.get(i).id);
        hide_tooltip(item_arr.get(i).id);
        if (item_is_empty(item_arr.get(i).id)) {
            with_errors = true;
        }
    }
    for (var i in input_arr) {
        if (with_errors)
            disable_input(input_arr.get(i).id);
        else
            enable_input(input_arr.get(i).id);
    }
    if (!production_mode)
        console.log('interface reseted');
}

function validator(item_id, items, inputs) {
    return function() {
        $('#' + item_id).on('focus click', function() {
            hide_tooltip(item_id);
        });
        $('#' + item_id).on('input blur', function () {
            if (item_is_empty(item_id)) {
                if (!production_mode)
                    console.log('item "' + item_id + '" is invalid. disabling all inputs');
                set_error_colors(item_id);
                show_tooltip(item_id, 'Обязательное поле');
                for (var i in inputs) {
                    disable_input(inputs[i]);
                }
            } else {
                hide_tooltip(item_id);
                if (!production_mode)
                    console.log('item "' + item_id + '" is valid. checking all items');
                set_valid_colors(item_id);
                var with_errors = false;
                for (var j in items) {
                    if (item_is_empty(items[j])) {
                        with_errors = true;
                        if (!production_mode)
                            console.log('item "' + items[j] + '" is invalid. disabling all inputs');
                        break;
                    }
                }
                if (!with_errors) {
                    if (!production_mode)
                        console.log('all items is valid. enabling all inputs');
                }
                for (var k in inputs) {
                    if (with_errors) {
                        disable_input(inputs[k]);
                    } else {
                        enable_input(inputs[k]);
                    }
                }
            }
        });
    };
}

function class_adder(item_id, class_name) {
    return function() {
        $('#' + item_id).addClass(class_name);
    }
}

function set_validators() {

    var items = this.action.attribute01.split(',');
    var inputs = this.action.attribute02.split(',');

    for (var i in items) {
        var f = validator(items[i], items, inputs);
        f();
        var ca = class_adder(items[i], 'not_empty_item');
        ca();
    }
    for (var i in inputs) {
        var ca = class_adder(inputs[i], 'not_empty_button');
        ca();
    }
}



на странице несколько регионов. чтобы очистить элементы на определенном регионе, на странице дописал такую строчку:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
$('#REGION_APP').dialog({
    autoOpen: false,
    resizable: false,
    modal: true,
    width: '800px',
    maxWidth: 800,
    open: function() {
        reset_interface($(this).get(0).id); // $(this).get(0).id - это как раз id родительского региона
    }
});
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880772
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89,

Ну я понял, что в итоге ты меня проигнорировал.
Ответь мне вот на такой вопрос. Вот эти функции, ты где цепляешь к странице?
Внутри плагина? Тогда, как же ты решил проблему многократного использования плагина?
На странице? Тогда это полуплагин...
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880775
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
по поводу вашего кода: вы в pl/sql не добавили 3-й атрибут и не написали про него что он должен содержать. я не очень понял. и еще:
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function init_validators() {
	var meFun=this;
	if (!myObj) {
		var myObj={};
	};
	var myObj[meFun.action.attribute03] = {
		items : meFun.action.attribute01.split(','),
		buttons : meFun.action.attribute02.split(','),
		reset : function () {
			var me=this;
			console.log(me.items);
			console.log(me.buttons);
		},
		setValidation : function () {
			var me=this;
			for (var i in me.items) {	
				var f = me.validator(me.items[i], me.items, me.inputs);
			}
		},
		validator : function(item_id, items, inputs) {
			....
		}
	};
};


допустим я создам локальную переменную myObj внутри init_validators. но достучаться до нее будет нельзя извне этой функции.

ситуация следующая: вот я создал на странице три региона. каждый из регионов изначально не отображается на странице, это делается через jquery ui dialog при нажатии на кнопку "добавить". в каждом регионе по два поля ввода и по одной кнопке. соответственно на
странице 3 динамик экшена, каждый при Page Load выполняет мой плагин, который привязывает обработчики событий к соответствующим элементам.

а теперь мне надо добавить следующую логику: при открытии каждого из этих регионов элементы интерфейса этого региона должны сбрасываться функцией reset_interface. сейчас проблема решена передачей в эту функцию id родительского региона. функция ищет в этом регионе элементы предопределенных классов ( у меня это not_empty_item и not_empty_button ) и работает с ними. по-другому вроде никак и не сделать
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880788
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
ну сейчас это не совсем то, чего я добивался. но непонятно, как сделать так, чтобы работало
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880792
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
вызов reset_interface происходит на странице...
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880797
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89,
Жестььььь........
Это называется, а не зайти ли мне с опы к данной проблеме.
Извините за мат, НАХЕРА ПЛАГИН? Чтобы бы посложнее все остальным было разобраться? Почему нельзя повесить ПРОСТО обработчик? Ну давайте tot дальше пойдем, сделаем плагин региона(рисовать элементы будет), на который навесим плагин DA (обработчики вешать).

Можно увидеть не решение задачи, а саму задачу?
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880813
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
в виде плагина я это оформил потому что планирую это на всех страницах впилить. с валидацией то все как раз хорошо. одна проблема только с получением атрибутов из других функций. вы предложили локальную переменную создать, но если к ней доступа извне нет то зачем это? сейчас не самое красивое, но рабочее решение
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880900
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89,

Как любит тут один из наших постоянных посетителей форума выражаться, плагин нужен, если им можно и нужно управлять декларативно, если же для плагина нужно дописывать на каждой странице что то, то это хрень, а не плагин. Подход не правильный....

Создание индивидуального объекта, внутри плагина, решает проблему многоразового использования этого плагина. Почему вы не можете обратится к объекту из вне, я не понимаю...

А так же рассмотрите такой вариант, он мне кажется куда проще, чем плагин, тем более, что с яваскриптом на ты.
Объекты можно создавать динамически, например, вы определяете глобальную функцию, на весь апекс.
Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
function myMultiObject (items,inputs)  {
	myMultiObject=this;
	myMultiObject.items=items;
	myMultiObject.items=inputs
	myMultiObject.reset=function() {
		var me=this;
		console.log(me.items);
		console.log(me.buttons);
	};
	myMultiObject.setValidation =function () {
		var me=this;
		for (var i in me.items) {	
			var f = me.validator(me.items[i], me.items, me.inputs);
		}
	};
	myMultiObject.validator : function(item_id, items, inputs) {
			....
	};
};
//И вызывать их в хеадере региона 
var newObj = new  myMultiObject("PXX_PPP;PXX_PPP3;PXX_PPP2;PXX_PPP1;","INPUT1;INPUT2;INPUT3;INPUT4;INPUT5;")
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38880911
Фотография Petro123
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Diagnost89,
вы так и не ответили - цель вашего плагина.
- есть штатная система валидации
- есть штатная Read only
- есть штатная для рендеринга Condition.
Чем они не устроили?
Возможно вы экономите на спичках, а 90 процентов времени будет уходить на логику страницы, а не на то что вы пишите.
imho
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881011
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
цель - сделать так, чтобы унифицированно проверялись поля. и если они введены неправильно то выводились сообщения об ошибках и блокировались кнопки на форме (например блокировалась кнопка "сохранить"). это сейчас решено и управляется декларативно. тут все ок. сама проблема в том что нужна еще функция, которая сбрасывает состояние региона в начальное состояние. сейчас она решена как раз не совсем хорошо - вызовом функции в футере региона.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
<script>
$('#REGION_APP').dialog({
    autoOpen: false,
    resizable: false,
    modal: true,
    width: '800px',
    maxWidth: 800,
    open: function() {
        reset_interface($(this).get(0).id);
    }
});
</script>



то есть если форму неправильно заполнили и потом закрыли то при открытии это уже не будет отображаться
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881023
Diagnost89
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
а с вашим примером который вы уже много раз предложили я так и не могу разобраться.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
}

say.hello(); // Uncaught TypeError: undefined is not a function
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881061
Фотография Petro123
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Diagnost89цель - сделать так, чтобы унифицированно проверялись поля. и если они введены неправильно то выводились сообщения об ошибках и блокировались кнопки на форме (например блокировалась кнопка "сохранить").
- Validations смотрели? Хотя я предпочитаю проверки на сервере в триггере.
- DA - Event type - блокировка кнопок смотрели?
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881365
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89а с вашим примером который вы уже много раз предложили я так и не могу разобраться.

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
};

say.hello(); // Uncaught TypeError: undefined is not a function


Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
function say() {
	say = this;
	say.hello = function() {
		alert('hello, world!');
	};
};
var mySay =new say();
mySay.hello();
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881480
blkangel
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Diagnost89то есть если форму неправильно заполнили и потом закрыли то при открытии это уже не будет отображаться
А вот тут не понял.
Можно чтобы сохранялось, можно чтобы очищалось. Есть такое понятие как ClearCache, Апекс давно уже написал функцию, которая чистит поля.
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881491
Фотография Petro123
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
blkangel,
+1
это веб. И тут трудно понять, что кому надо.
Некоторые ждут - "с чистого листа, т.к. не сохраняли".
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881493
SvDev
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
указанный выше способ скорее для библиотеки, а не для конструктора.

Не уверен что понимаю задачу, но вообще я знаю 3 способа взаимодействия с плагинами:

1. через массив, допустим

Код: plsql
1.
render_result.javascript_function := 'init_validators("'||to_char(p_dynamic_action.id)||'")';



можно определить глобальную функцию, которая по входному параметру p_dynamic_action.id будет обращаться к значениям соответствующего экземпляра плагина

на примере функции say:

Код: javascript
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
function say() { 
  
  if (!gObjArr)  var gObjArr = []; 
  var gObj = {}; 
  
  gObj.ActionId = 10; 
  gObj.ItemList = 'PX_MYITEM'; 
  
  gObjArr.push(gObj);  
  
  window.hello = function(pActionID) { 
  
    alert( gObjArr.filter( function(pObj) { return pObj.ActionId = pActionID } )[0].ItemList );
  };
  
  window.GetObj = function(pActionID) { 
  
    return gObjArr.filter( function(pObj) { return pObj.ActionId = pActionID } )[0];
  };
}

say();
hello(10);
alert( GetObj(10).ItemList );



Соответственно, обработчик hello по переданному ActionID реализует некоторый стандартный метод,
обработчик GetObj по переданному ActionID возвращает object, в котором хранятся данные плагина.

Тут вместо say будет init_validators (вызывается автоматически), вместо gObj скажем this.action, который дополнить значением ActionId и т.д.
ActionId при вызове hello можно взять из apex_dictionary

метод filter не работает в ie8, чтобы работало можно выполнить где-нибудь при инициализации что-нибудь вроде

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
if (!Array.prototype.filter)
{
  Array.prototype.filter = function(fun /*, thisp */)
  {
    "use strict";

    if (this === void 0 || this === null)
      throw new TypeError();

    var t = Object(this);
    var len = t.length >>> 0;
    if (typeof fun !== "function")
      throw new TypeError();

    var res = [];
    var thisp = arguments[1];
    for (var i = 0; i < len; i++)
    {
      if (i in t)
      {
        var val = t[i]; // in case fun mutates this
        if (fun.call(thisp, val, i, t))
          res.push(val);
      }
    }

    return res;
  };
}




2. второй способ - вместо массива использовать события, которые рассылать элементам, над которыми плагин производит действия, внутрь можно передать необходимые данные

т.е., например, добавляем в плагин событие myEvent
плагин производит действие с элементом (допустим с Items-ом PX_MYITEM), после чего рассылает это событие:

Код: javascript
1.
2.
3.
4.
5.
6.
var gObj = {}; 
  
gObj.ActionId = 10; 
gObj.ItemList = 'PX_MYITEM'; 

$("#PX_MYITEM").trigger("myEvent", gObj);



тогда можно создать Dynamic Action:

Event: myEvent
Selection Type: Jquery Selector
jQuery Selector: #PX_MYITEM

Внутри Action можно будет обратиться к данным плагина:

alert(this.data.ItemList);

3. Третий способ - добавить атрибут, куда можно вписать обработчик яваскрипт при создании самого плагина, тогда обработчику можно будет предоставить необходимый интерфейс, через который можно обратиться к свойствам и методам, типа this.data и др.

Но третий я бы не рекоммендовал делать в большинстве случаев.
...
Рейтинг: 0 / 0
Доступ к атрибутам плагина из javascript
    #38881537
SvDev
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
4. Можно еще создать глобальные методы с динамическими именами на основе p_dynamic_action.id, потом поизвращаться с функцией eval, или яваскрипт код генерировать динамически через pl/sql, но я не думаю, что это правильный подход, т.к. использование eval считается плохим тоном, точно так же как делать зависимым яваскрипт от pl/sql слишком сильно.

Впрочем он может иметь смысл с плагинами другого типа, когда плагин генерирует html на основе элементов с определенными именами, тогда плагин может догенерировать элементы с похожими именами, (например элемент имя item + приставка "_display" и т.д), но такой подход не подходит для данного вида плагина по архитектурным соображениям, имхо.
...
Рейтинг: 0 / 0
25 сообщений из 42, страница 1 из 2
Форумы / Oracle APEX [игнор отключен] [закрыт для гостей] / Доступ к атрибутам плагина из javascript
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]