Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   проблема с ООП (https://javascript.ru/forum/misc/1093-problema-s-oop.html)

Kolyaj 17.03.2008 17:00

Цитата:

Сообщение от scuter
Javascript для PHP функции: isset

Ах вон оно что. Мой вам скромный совет: не ходите в тот раздел, пишите на JavaScript, а не на PHP для JavaScript.

scuter 17.03.2008 20:41

да нет написал так как в последнем примере,
а isset использовал потому, что не мог понять почему не if(node.error)
не срабатывает, а оказалось такая конитель.

кстати в IE 6 что то не срабатывает у вас на форуме,
толи стили не подгружаются толи с js какой то косяк.

Dmitry A. Soshnikov 17.03.2008 22:47

Цитата:

Сообщение от scuter
что не мог понять почему не if(node.error) не срабатывает

если падает с ошибкой, то потому что node не определен

Андрей Параничев 18.03.2008 01:08

scuter,
Если еще осталась проблема, пожалуйста, опиши её максимально подробно, так как сейчас - ничего не понятно.

scuter 18.03.2008 01:20

я её максимально понятно описал,
остаётся только код полностью выложить(но он слишком большой для этого),
Андрей Параничев,
ты наверное прав ext наверное запускается в этом режиме
так как функцию я объявляю внутри Ext.onReady
примерно так,
Ext.onReady(function(){
var TreePanetEdit = function(box)
{
    if(box)
    {
        alert(box);
    }
    else
    {
        alert('nexus');
    }
}
});

Андрей Параничев 18.03.2008 16:53

Так, давайте по порядку :)
Что вы хотите, просто заменить функцию onReady объекта/класса Ext?
Или хотите чтоб в коде
Ext.onReady(function(){
var TreePanetEdit = function(box)
{
    if(box)
    {
        alert(box);
    }
    else
    {
        alert('nexus');
    }
}
});

Функцию TreePanetEdit можно было запускать откуда угодно? Я просто не знаю как сделан код Ext (вряд ли с полной инкапсуляцией), в любом случае достаточно, чтобы функция при onLoad видела другие функции, так как весь исполнительный код помещать в событие onLoad не обязательно - только вызов определённых методов.

Или я опять неправильно вас понял? :)

scuter 18.03.2008 19:07

у сейчас там есть такой код,
Ext.onReady(function(){
	var TreeNodeAdd = page.TreeNodeAdd;
	var TreeNodeMove = page.TreeNodeMove;
	var TreeNodeRename = page.TreeNodeRename;
	var TreeNodeDelete = page.TreeNodeDelete
	var TreeNodeBeforeStartEdit = page.TreeNodeBeforeStartEdit;
	var TreeNodeUrl = page.TreeNodeUrl;
	var TabAdd = page.TabAdd;
	var TreePanetEdit = function(bottom)
    {
    	if((bottom == 'Add') || (bottom == 'AddChild'))
    	{
	    	NodeSelect = tree.getSelectionModel().getSelectedNode();
	    	if(bottom == 'Add')
	    	{
	    		NodeEdit = NodeSelect;
	    	}
	    	else
	    	{
	    		NodeEdit = NodeSelect.parentNode;
	    	}
	    	node = NodeChild = TreeNodeAdd(NodeEdit);
	    	if(NodeChild.add)
			{
	    		Child = new Ext.tree.TreeNode(NodeChild.add);
	    		NodeEdit.appendChild(Child);
			}
    	}
    	else if(bottom == 'TreeNodeUp')
    	{
    		node = TreeNodeMove('Up');
    		if(!node.error)
    		{
    			tree.loader.load(tree.root);
    		}
    	}
    	else if(bottom == 'TreeNodeDown')
    	{
    		node = TreeNodeMove('Down');
    		if(!node.error)
    		{
    			tree.loader.load(tree.root);
    		}
    	}
    	else if(bottom == 'TreeNodeDelete')
    	{
    		node = tree.getSelectionModel().getSelectedNode();
    		node = TreeNodeDelete(node);
    		if(!node.error)
    		{
    			tree.loader.load(tree.root);
    		}
    	}
    	if(node)
    	{
    		if(node.error)
	    	{
	    		if(isset('node.error.title') && isset('node.error.text'))
	    		{
	    			Ext.MessageBox.show({
						title: node.error.title,
						msg: node.error.text,
						buttons: Ext.MessageBox.OK,
						icon: 'error'
					});
	    		}
	    	}
	    	else if(node.msg)
	    	{
	    		if(node.msg.title && node.msg.text)
	    		{
	    			Ext.MessageBox.show({
						title: node.msg.title,
						msg: node.msg.text,
						buttons: Ext.MessageBox.OK,
						icon: 'info'
					});
	    		}
	    	}
    	}
    }
var TreeToolbar = new Ext.Toolbar({
		cls:'TreeToolbar',
		items:[
		{
	        id:'add',
	        iconCls:'add',
	        handler:function(){TreePanetEdit('Add');},
	        tooltip:'Добавить сраницу.'
	    }, {
	        id:'add_p',
	        iconCls:'plugin_add',
	        handler:function(){TreePanetEdit('AddChild')},
	        tooltip:'Добавить подстраницу.'
	    },'-',{
	    	id:'up',
	        iconCls:'arrow-up',
	        handler:function(){TreePanetEdit('TreeNodeUp')},
	        tooltip:'переместить выше.'
	    },{
	    	id:'down',
	        iconCls:'arrow-down',
	        handler:function(){TreePanetEdit('TreeNodeDown')},
	        tooltip:'переместить ниже.'
	    },'-',{
	        id:'remove',
	        iconCls:'delete',
	        handler:function(){TreePanetEdit('TreeNodeDelete')},
	        tooltip:'Удалить страницу'
	    }
	    ]
    });
    var TreeToolbarMap = TreeToolbar.items.map;
});
var page = new (function(){
	this.TreeNodeAdd = function()
	{
		
	}
	this.TreeNodeUp = function()
	{
		
	}
	this.TreeNodeDown = function()
	{
		
	}
	this.TreeNodeRename = function()
	{
		
	}
	this.TreeNodeDelete = function()
	{
		
	}
	this.TreeReplace = function()
	{
		
	}
	this.TreeNodeBeforeStartEdit = function()
	{
		
	}
	this.TreeNodeUrl = '/admin/src/page_tree_menu:content';
	this.TabAdd = function()
	{
		
	}
})();

раньше когда я перекидывал функции из page в onReady
функции не видели переменных которые были в onReady
пока возился приключился косяк функции начали выполняться один раз при запуску а потом не использовались,
но это дело я обошёл только вот не понял почему надо писать так
handler:function(){TreePanetEdit('Add');},

scuter 23.03.2008 06:02

хм, кажется все таки непонятно объяснил,
есть два объекта,

Ext.onReady(function(){
	var table = 'kjsfdgjkdjfh';
	var TreeNodeAdd = page.TreeNodeAdd;
	var TreeNodeMove = page.TreeNodeMove;
	var TreeNodeRename = page.TreeNodeRename;
	var TreeNodeDelete = page.TreeNodeDelete
	var TreeNodeBeforeStartEdit = page.TreeNodeBeforeStartEdit;
	var TreeNodeUrl = page.TreeNodeUrl;
	var TabAdd = page.TabAdd;
});

var page = new (function(){
	this.TreeNodeAdd = function()
	{
		alert(table);
	}
	this.TreeNodeUp = function()
	{
		
	}
	this.TreeNodeDown = function()
	{
		
	}
	this.TreeNodeRename = function()
	{
		
	}
	this.TreeNodeDelete = function()
	{
		
	}
	this.TreeReplace = function()
	{
		
	}
......
})();

ну тук вот я не понимаю почему функция не видит переменную table,
скажите как сделать так, что бы видела.

Андрей Параничев 23.03.2008 13:50

Ext.onReady(function(){
    table = 'kjsfdgjkdjfh';
    var TreeNodeAdd = page.TreeNodeAdd;
    var TreeNodeMove = page.TreeNodeMove;
    var TreeNodeRename = page.TreeNodeRename;
    var TreeNodeDelete = page.TreeNodeDelete
    var TreeNodeBeforeStartEdit = page.TreeNodeBeforeStartEdit;
    var TreeNodeUrl = page.TreeNodeUrl;
    var TabAdd = page.TabAdd;
});
 
var page = new (function(){
    this.TreeNodeAdd = function()
    {
        alert(table);
    }
    this.TreeNodeUp = function()
    {
        
    }
    this.TreeNodeDown = function()
    {
        
    }
    this.TreeNodeRename = function()
    {
        
    }
    this.TreeNodeDelete = function()
    {
        
    }
    this.TreeReplace = function()
    {
        
    }
......
})();

scuter 23.03.2008 22:48

Андрей Параничев,
это шутка?


Часовой пояс GMT +3, время: 00:33.