This code dosen't function properly on google chrome, and mozilla firefox, just on IE. The problem is that, it allways put's the box on the left uppercorner, I need to the box to appear to the place where I clicked it. So if anybody could help me with the move_box function, I would really appreciate. -
function move_box(an, box)
-
-
{
-
-
var cleft = 0;
-
-
var ctop = 0;
-
-
var obj = an;
-
-
-
-
while (obj.offsetParent)
-
-
{
-
-
cleft += obj.offsetLeft;
-
-
ctop += obj.offsetTop;
-
-
obj = obj.offsetParent;
-
-
}
-
-
-
-
box.style.left = cleft + 'px';
-
-
-
-
ctop += an.offsetHeight + 8;
-
-
-
-
// Handle Internet Explorer body margins,
-
-
// which affect normal document, but not
-
-
// absolute-positioned stuff.
-
-
if (document.body.currentStyle &&
-
-
document.body.currentStyle['marginTop'])
-
-
{
-
-
ctop += parseInt(document.body.currentStyle['marginTop']);
-
-
}
-
-
-
-
box.style.top = ctop + 'px';
-
-
}
-
-
-
-
// Shows a box if it wasn't shown yet or is hidden
-
-
// or hides it if it is currently shown
-
-
function show_hide_box(an, width, height, borderStyle)
-
-
{
-
-
var href = an.href;
-
-
var boxdiv = document.getElementById(href);
-
-
-
-
if (boxdiv != null)
-
-
{
-
-
if (boxdiv.style.display=='none')
-
-
{
-
-
// Show existing box, move it
-
-
// if document changed layout
-
-
move_box(an, boxdiv);
-
-
boxdiv.style.display='block';
-
-
-
-
bringToFront(boxdiv);
-
-
-
-
// Workaround for Konqueror/Safari
-
-
if (!boxdiv.contents.contentWindow)
-
-
boxdiv.contents.src = href;
-
-
}
-
-
else
-
-
// Hide currently shown box.
-
-
boxdiv.style.display='none';
-
-
return false;
-
-
}
-
-
-
-
// Create box object through DOM
-
-
boxdiv = document.createElement('div');
-
-
-
-
// Assign id equalling to the document it will show
-
-
boxdiv.setAttribute('id', href);
-
-
-
-
boxdiv.style.display = 'block';
-
-
boxdiv.style.position = 'absolute';
-
-
boxdiv.style.width = width + 'px';
-
-
boxdiv.style.height = height + 'px';
-
-
boxdiv.style.border = borderStyle;
-
-
boxdiv.style.textAlign = 'right';
-
-
boxdiv.style.padding = '4px';
-
-
boxdiv.style.background = '#FFFFFF';
-
-
document.body.appendChild(boxdiv);
-
-
bringToFront(boxdiv);
-
-
-
-
var offset = 0;
-
-
-
-
// Remove the following code if 'Close' hyperlink
-
-
// is not needed.
-
-
var close_href = document.createElement('a');
-
-
close_href.href = 'javascript:void(0);';
-
-
close_href.onclick = function()
-
-
{ show_hide_box(an, width, height, borderStyle); }
-
-
close_href.appendChild(document.createTextNode('Close'));
-
-
boxdiv.appendChild(close_href);
-
-
offset = close_href.offsetHeight;
-
-
// End of 'Close' hyperlink code.
-
-
-
-
var contents = document.createElement('iframe');
-
-
//contents.scrolling = 'no';
-
-
contents.overflowX = 'hidden';
-
-
contents.overflowY = 'scroll';
-
-
contents.frameBorder = '0';
-
-
contents.style.width = width + 'px';
-
-
contents.style.height = (height - offset) + 'px';
-
-
-
-
boxdiv.contents = contents;
-
-
boxdiv.appendChild(contents);
-
-
-
-
move_box(an, boxdiv);
-
-
-
-
if (contents.contentWindow)
-
-
contents.contentWindow.document.location.replace(
-
-
href);
-
-
else
-
-
contents.src = href;
-
-
-
-
// The script has successfully shown the box,
-
-
// prevent hyperlink navigation.
-
-
return false;
-
-
}
-
-
-
-
function getAbsoluteDivs()
-
-
{
-
-
var arr = new Array();
-
-
var all_divs = document.body.getElementsByTagName("DIV");
-
-
var j = 0;
-
-
-
-
for (i = 0; i < all_divs.length; i++)
-
-
if (all_divs.item(i).style.position=='absolute')
-
-
{
-
-
arr[j] = all_divs.item(i);
-
-
j++;
-
-
}
-
-
-
-
return arr;
-
-
}
-
-
-
-
function bringToFront(obj)
-
-
{
-
-
if (!document.getElementsByTagName)
-
-
return;
-
-
-
-
var divs = getAbsoluteDivs();
-
-
var max_index = 0;
-
-
var cur_index;
-
-
-
-
// Compute the maximal z-index of
-
-
// other absolute-positioned divs
-
-
for (i = 0; i < divs.length; i++)
-
-
{
-
-
var item = divs[i];
-
-
if (item == obj ||
-
-
item.style.zIndex == '')
-
-
continue;
-
-
-
-
cur_index = parseInt(item.style.zIndex);
-
-
if (max_index < cur_index)
-
-
{
-
-
max_index = cur_index;
-
-
}
-
-
}
-
-
-
-
obj.style.zIndex = max_index + 1;
-
-
}
-
3 2593
This will be difficult to figure out without the HTML. Do you have this on the web or can you make a jsfiddle?
In any case, though IE is showing what you want, Firefox and Chrome will show what you wrote. Never, ever use IE as a reference for how things work.
Thank you for replying.
Yes I have this on web, here is the whole html and javascript code. The two pictures, Qyteti.jpg and you.jpg, I can send it to you, if necessary. -
-
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="mapguide1._Default" %>
-
-
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
-
-
<html xmlns="http://www.w3.org/1999/xhtml" >
-
<head runat="server">
-
<script src="popup.js" type="text/javascript"></script>
-
</head>
-
-
<body >
-
-
-
<img src="Qyteti.jpg" width="1500" height="1500" alt="Harta" usemap="#citymap" />
-
-
<map name="citymap">
-
-
<area shape="rect" coords="0,0,600,600" href="you.jpg" onclick="return show_hide_box(this, 200, 270, '2px solid')" alt="LE" />
-
<area shape="rect" coords="650,650,1200,1200" href="you.jpg" onclick="return show_hide_box(this, 200, 270, '2px solid')" alt="LE" />
-
-
-
</map>
-
-
-
-
-
-
-
-
<script type="text/javascript">
-
// Moves the box object to be directly beneath an object.
-
function move_box(an, box){
-
var cleft = 0;
-
var ctop = 0;
-
var obj = an;
-
while (obj.offsetParent) {
-
cleft += obj.offsetLeft;
-
ctop += obj.offsetTop;
-
obj = obj.offsetParent; }
-
-
box.style.left = cleft + 'px';
-
ctop += an.offsetHeight + 8;
-
-
// Handle Internet Explorer body margins,
-
// which affect normal document, but not
-
// absolute-positioned stuff.
-
-
if (document.body.currentStyle && document.body.currentStyle['marginTop']) {
-
-
ctop += parseInt(document.body.currentStyle['marginTop']); }
-
-
box.style.top = ctop + 'px';}
-
-
-
-
-
// Shows a box if it wasn't shown yet or is hidden
-
// or hides it if it is currently shownfunction
-
-
show_hide_box(an, width, height, borderStyle){
-
var href = an.href;
-
var boxdiv = document.getElementById(href);
-
if (boxdiv != null) {
-
if (boxdiv.style.display=='none') {
-
-
// Show existing box, move it
-
// if document changed layout
-
-
move_box(an, boxdiv); boxdiv.style.display='block'; bringToFront(boxdiv);
-
-
// Workaround for Konqueror/Safari
-
-
if (!boxdiv.contents.contentWindow)
-
-
boxdiv.contents.src = href; } else
-
-
// Hide currently shown box.
-
-
boxdiv.style.display='none';
-
return false; }
-
-
// Create box object through DOM
-
boxdiv = document.createElement('div');
-
-
// Assign id equalling to the document it will show
-
-
boxdiv.setAttribute('id', href);
-
boxdiv.style.display = 'block';
-
boxdiv.style.position = 'absolute';
-
boxdiv.style.width = width + 'px';
-
boxdiv.style.height = height + 'px';
-
boxdiv.style.border = borderStyle;
-
boxdiv.style.textAlign = 'right';
-
boxdiv.style.padding = '4px';
-
boxdiv.style.background = '#FFFFFF';
-
document.body.appendChild(boxdiv);
-
bringToFront(boxdiv); var offset = 0;
-
-
// Remove the following code if 'Close' hyperlink // is not needed.
-
-
var close_href = document.createElement('a');
-
close_href.href = 'javascript:void(0);';
-
close_href.onclick = function() {
-
-
show_hide_box(an, width, height, borderStyle); }
-
close_href.appendChild(document.createTextNode('Close'));
-
boxdiv.appendChild(close_href);
-
offset = close_href.offsetHeight;
-
-
// End of 'Close' hyperlink code. var contents = document.createElement('iframe');
-
-
//contents.scrolling = 'no';
-
contents.overflowX = 'hidden';
-
contents.overflowY = 'scroll';
-
contents.frameBorder = '0';
-
contents.style.width = width + 'px';
-
contents.style.height = (height - offset) + 'px';
-
boxdiv.contents = contents;
-
boxdiv.appendChild(contents);
-
-
move_box(an, boxdiv);
-
-
if (contents.contentWindow)
-
contents.contentWindow.document.location.replace( href);
-
-
else contents.src = href;
-
-
// The script has successfully shown the box,
-
// prevent hyperlink navigation.
-
-
return false;}
-
-
function getAbsoluteDivs(){
-
var arr = new Array();
-
var all_divs =
-
document.body.getElementsByTagName("DIV");
-
var j = 0;
-
for (i = 0; i < all_divs.length; i++)
-
-
if (all_divs.item(i).style.position=='absolute') { arr[j] = all_divs.item(i);
-
j++; }
-
return arr;}
-
-
function bringToFront(obj){
-
if (!document.getElementsByTagName)
-
return; var divs = getAbsoluteDivs();
-
var max_index = 0;
-
var cur_index;
-
-
// Compute the maximal z-index of
-
// other absolute-positioned divs
-
-
for (i = 0; i < divs.length; i++) {
-
var item = divs[i];
-
if (item == obj || item.style.zIndex == '') continue;
-
cur_index = parseInt(item.style.zIndex);
-
if (max_index < cur_index) { max_index = cur_index; } }
-
-
obj.style.zIndex = max_index + 1;}</script>
-
-
</body>
-
</html>
-
-
In your css, you have the body's margin set to zero and the modern browsers are honoring that. IE is not. I haven't looked to see why yet.
EDIT: Got distracted. That's not the main issue. Look at the error in the error console.
Sign in to post your reply or Sign up for a free account.
Similar topics |
by: James |
last post by:
I've been looking at the Mozilla source (1.8b1) and I thought that
there I might find definitions of the various client-side JavaScript
objects (e.g. history, navigator). Has anyone managed to...
|
by: Guy Macon |
last post by:
Serious Security Flaw in Google Chrome:
http://www.readwriteweb.com/archives/security_flaw_in_google_chrome.php
--
Guy Macon
<http://www.GuyMacon.com/>
|
by: wpjoju |
last post by:
i have this code which adds an event listener to a newly opened window but it doesn't seem to work in google chrome. the problem is window.addEventListener seem to work in chrome but if you do...
|
by: catoblepa80 |
last post by:
How can i read all google chrome bookmarks and place it into a list or a dictionary?
i think the best way is to use regular expressions on the chrome bookmarks file, can you help me to accomplish...
|
by: KeredDrahcir |
last post by:
When using an object tag to embed a video file everything looks fine in Internet Explorer and Safari. However I can't get it to display at all in Opera. More importantly in Firefox and Google Chrome...
| |
by: su817200 |
last post by:
Dear Friend,
Could you please let me know, how to enable ActiveX controls in Google Chrome Internet Browser. Is there any patch we need to install. Please let me know.
Rgds,
|
by: KeredDrahcir |
last post by:
Can anyone help me. I don't know if this is a mysql, php or Google Chrome error.
I have a login form but for some reason I'm getting an error when I use Google Chrome. It used to work in all...
|
by: Oralloy |
last post by:
Hello folks,
I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>".
The problem is that using the GNU compilers,...
|
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven...
|
by: agi2029 |
last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing,...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new...
| |
by: conductexam |
last post by:
I have .net C# application in which I am extracting data from word file and save it in database particularly. To store word all data as it is I am converting the whole word file firstly in HTML and...
|
by: TSSRALBI |
last post by:
Hello
I'm a network technician in training and I need your help.
I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs.
The...
|
by: 6302768590 |
last post by:
Hai team
i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated ...
|
by: muto222 |
last post by:
How can i add a mobile payment intergratation into php mysql website.
|
by: bsmnconsultancy |
last post by:
In today's digital era, a well-designed website is crucial for businesses looking to succeed. Whether you're a small business owner or a large corporation in Toronto, having a strong online presence...
| |