Javascript et nouveaux cadres

Fermé
jonas001 Messages postés 83 Date d'inscription vendredi 12 mars 2004 Statut Membre Dernière intervention 31 mars 2017 - 26 févr. 2006 à 13:43
 king - 26 févr. 2006 à 15:24
Bonjour à tous,

Voila : je suis en train de travailler sur un site web et j'utilise du javascript (même si je n'y comprends rien, j'ai construit une barre de menus sur un site qui en proposait ; pour la barre de menus voir sur mon ébauche de site http://verslescimes.free.fr/test/hmtl/notre_centre.htm par exemple)

Mon problème est le suivant : lors des deux premiers clics sur des onglets de ce menu, il y a une nouvelle page qui s'ouvre. Or je voudrais que ça s'ouvre dans la même page...

Le script utilise un fichier "menu.js" dont voici ci-desssous le code source : j'y vois bien marqué des "children" "parent" ou "container" mais je ne sais pas quoi y modifier ...
Ce code est peut-être un peu fastidieux, je suis désolé, mais je suis bien embêté vec cette histoire ...

Un pro du javascript pourrait-il m'aider ?
Merci d'avance !!

jonas



var menus = [];

// --- menu class ---
function menu (item_struct, pos, styles) {
// browser check
this.item_struct = item_struct;
this.pos = pos;
this.styles = styles;
this.id = menus.length;
this.items = [];
this.children = [];

this.add_item = menu_add_item;
this.hide = menu_hide;

this.onclick = menu_onclick;
this.onmouseout = menu_onmouseout;
this.onmouseover = menu_onmouseover;
this.onmousedown = menu_onmousedown;

var i;
for (i = 0; i < this.item_struct.length; i++)
new menu_item(i, this, this);
for (i = 0; i < this.children.length; i++)
this.children[i].visibility(true);
menus[this.id] = this;
}
function menu_add_item (item) {
var id = this.items.length;
this.items[id] = item;
return (id);
}
function menu_hide () {
for (var i = 0; i < this.items.length; i++) {
this.items[i].visibility(false);
this.items[i].switch_style('onmouseout');
}
}
function menu_onclick (id) {
var item = this.items[id];
return (item.fields[1] ? true : false);
}
function menu_onmouseout (id) {
this.hide_timer = setTimeout('menus['+ this.id +'].hide();',
this.pos['hide_delay'][this.active_item.depth]);
if (this.active_item.id == id)
this.active_item = null;
}
function menu_onmouseover (id) {
this.active_item = this.items[id];
clearTimeout(this.hide_timer);
var curr_item, visib;
for (var i = 0; i < this.items.length; i++) {
curr_item = this.items[i];
visib = (curr_item.arrpath.slice(0, curr_item.depth).join('_') ==
this.active_item.arrpath.slice(0, curr_item.depth).join('_'));
if (visib)
curr_item.switch_style (
curr_item == this.active_item ? 'onmouseover' : 'onmouseout');
curr_item.visibility(visib);
}
}
function menu_onmousedown (id) {
this.items[id].switch_style('onmousedown');
}
// --- menu item Class ---
function menu_item (path, parent, container) {
this.path = new String (path);
this.parent = parent;
this.container = container;
this.arrpath = this.path.split('_');
this.depth = this.arrpath.length - 1;
// get pointer to item's data in the structure
var struct_path = '', i;
for (i = 0; i <= this.depth; i++)
struct_path += '[' + (Number(this.arrpath[i]) + (i ? 2 : 0)) + ']';
eval('this.fields = this.container.item_struct' + struct_path);
if (!this.fields) return;

// assign methods
this.get_x = mitem_get_x;
this.get_y = mitem_get_y;
// these methods may be different for different browsers (i.e. non DOM compatible)
this.init = mitem_init;
this.visibility = mitem_visibility;
this.switch_style = mitem_switch_style;

// register in the collections
this.id = this.container.add_item(this);
parent.children[parent.children.length] = this;

// init recursively
this.init();
this.children = [];
var child_count = this.fields.length - 2;
for (i = 0; i < child_count; i++)
new menu_item (this.path + '_' + i, this, this.container);
this.switch_style('onmouseout');
}
function mitem_init() {
document.write (
'<a id="mi_' + this.container.id + '_'
+ this.id +'" class="m' + this.container.id + 'l' + this.depth
+'o" href="' + this.fields[1] + '" style="position: absolute; top: '
+ this.get_y() + 'px; left: ' + this.get_x() + 'px; width: '
+ this.container.pos['width'][this.depth] + 'px; height: '
+ this.container.pos['height'][this.depth] + 'px; visibility: hidden;'
+' background: black; color: white; z-index: ' + this.depth + ';" '
+ 'onclick="return menus[' + this.container.id + '].onclick('
+ this.id + ');" onmouseout="menus[' + this.container.id + '].onmouseout('
+ this.id + ');" onmouseover="menus[' + this.container.id + '].onmouseover('
+ this.id + ');" onmousedown="menus[' + this.container.id + '].onmousedown('
+ this.id + ');"><div class="m' + this.container.id + 'l' + this.depth + 'i">'
+ this.fields[0] + "</div></a>\n"
);
this.element = document.getElementById('mi_' + this.container.id + '_' + this.id);
}
function mitem_visibility(make_visible) {
if (make_visible != null) {
if (this.visible == make_visible) return;
this.visible = make_visible;
if (make_visible)
this.element.style.visibility = 'visible';
else if (this.depth)
this.element.style.visibility = 'hidden';
}
return (this.visible);
}
function mitem_get_x() {
var value = 0;
for (var i = 0; i <= this.depth; i++)
value += this.container.pos['block_left'][i]
+ this.arrpath[i] * this.container.pos['left'][i];
return (value);
}
function mitem_get_y() {
var value = 0;
for (var i = 0; i <= this.depth; i++)
value += this.container.pos['block_top'][i]
+ this.arrpath[i] * this.container.pos['top'][i];
return (value);
}
function mitem_switch_style(state) {
if (this.state == state) return;
this.state = state;
var style = this.container.styles[state];
for (var i = 0; i < style.length; i += 2)
if (style[i] && style[i+1])
eval('this.element.style.' + style[i] + "='"
+ style[i+1][this.depth] + "';");
}
A voir également:

3 réponses

Si ce sont des cadres, dans ton lien suffit de mettre target="nom du cadre" et ça s'ouvre où tu veux :-)
0
jonas001 Messages postés 83 Date d'inscription vendredi 12 mars 2004 Statut Membre Dernière intervention 31 mars 2017 9
26 févr. 2006 à 14:50
Salut,
Merci d'avoir répondu tout d'abord.

Effectivement je pourrais faire ça, mais là c'est du javascript et nulle part il n'y a écrit target. C'est comme pour mes liens, ils sont obtenus grâce à un autre fichier .js (menus_items.js) mais dans ce fihier il y a juste les liens, pas la manière de les ouvri.

jonas
0
Suis un peu à la bourre là, si j'ai le temps ce soir ou demain, je vais mâter plus profondément.


vise les <a href=""> et derrière ajoute un target, donc:

<a href="www.blabla.com" taget="mon cadre">

Si c'est monté de façon plus compliquée, faudra que je mâte plus attentivement, d'ici demain en gros si personne d'autre ne s'inquiète de ton cas :-)
0