Hello! I was wondering if someone could help me out with a problem I'm
having? I'm trying to input a javascript value into an anchor tag
(from a function), but don't have an event to call the function...if
that makes sense. Here's what I mean...
I have a javascript array set up like so:
<script language="javascript" TYPE="text/JavaScript">
//custom object constructor
function theImage(path, width, height, link)
{
this.path = path;
this.width = width;
this.height = height;
this.link = link;
}
var arrayImages = new Array()
arrayImages[0] = new theImage("/somelink_a.jpg", "216", "302",
"/somelink_b.jpg");
arrayImages[1] = new theImage(/anotherimage_a.jpg", "216", "302",
"/anotherimage_b.jpg");
etc, etc...
And I have the following javascript functions...
function getLink(i)
{
var currentLink = arrayImages[i].link;
return currentLink;
}
function getPath(i)
{
var currentPath = arrayImages[i].path;
return currentPath;
}
function getWidth(i)
{
var currentWidth = arrayImages[i].width;
return currentWidth;
}
function getHeight(i)
{
var currentHeight = arrayImages[i].height;
return currentHeight;
}
Now, for the HTML...
When I call these four functions through a body onLoad, like this:
<body class="background_color"
onLoad="alert(getLink(1));alert(getPath(1));alert( getWidth(1));alert(getHeight(1));">
the values '/anotherimage_a.jpg"', '216', '302', '/anotherimage_b.jpg'
are returned in the alert. But, I would like to have these values
returned in an anchor tage like so...
<a href="javascript:getLink(1);" target="_blank"><img
src="javascript:getPath(1);" width="javascript:getWidth(1);"
height="javascript:getHeight(1);" border="0"><br>LARGER IMAGE</a>
Is this possible? Is there a workaround for this? Any help would be
VERY appreciated!! 5 25811 el**********@yahoo.com wrote: Hello! I was wondering if someone could help me out with a problem I'm having? I'm trying to input a javascript value into an anchor tag (from a function), but don't have an event to call the function...if that makes sense. Here's what I mean...
I have a javascript array set up like so:
<script language="javascript" TYPE="text/JavaScript">
//custom object constructor function theImage(path, width, height, link) { this.path = path; this.width = width; this.height = height; this.link = link; }
var arrayImages = new Array()
arrayImages[0] = new theImage("/somelink_a.jpg", "216", "302", "/somelink_b.jpg"); arrayImages[1] = new theImage(/anotherimage_a.jpg", "216", "302", "/anotherimage_b.jpg");
etc, etc...
And I have the following javascript functions...
function getLink(i) { var currentLink = arrayImages[i].link; return currentLink; }
Please don't post code with tabs, use 2 or four spaces for indents.
These functions can be written like this:
function getLink(i) {
return = arrayImages[i].link;
}
[...] Now, for the HTML...
When I call these four functions through a body onLoad, like this:
<body class="background_color" onLoad="alert(getLink(1));alert(getPath(1));alert( getWidth(1));alert(getHeight(1));">
the values '/anotherimage_a.jpg"', '216', '302', '/anotherimage_b.jpg' are returned in the alert. But, I would like to have these values returned in an anchor tage like so...
<a href="javascript:getLink(1);" target="_blank"><img src="javascript:getPath(1);" width="javascript:getWidth(1);" height="javascript:getHeight(1);" border="0"><br>LARGER IMAGE</a>
This seems pretty futile, but I'll play along anyway. Presumably the
A elements are in the HTML source and you want to use JavaScript to
add properties. You could use the links collection, but it's likely
you have other images in your document so you can use ID's. You
could also give all the A elements you want to modify the same name
and then use getElementsByName, the following example uses IDs.
Give all your A elements an id like "anchor-1", "anchor-2", etc.:
<html><head><title>blah</title>
</head><body onload="addAs();">
<script type="text/javascript">
function theImage(path, width, height, link) {
this.path = path;
this.width = width;
this.height = height;
this.link = link;
}
var arrayImages = [];
arrayImages[0] = new theImage("a.jpg", "216", "302","a.jpg");
arrayImages[1] = new theImage("a.jpg", "216", "302","a.jpg");
function addAs() {
if ( !document.getElementById
|| !document.createElement
|| !arrayImages ) {
return;
}
var x, i, j=arrayImages.length;
for ( i=0; i<j; i++ ){
x = document.getElementById('anchor-'+i);
if ( x ) {
x.href = getLink(i);
var oImg = document.createElement('img');
oImg.src = getPath(i);
oImg.width = getWidth(i);
oImg.height = getHeight(i);
oImg.alt =
'Sunset over the Outer Barcoo (where fences are few)';
x.appendChild(oImg);
}
}
}
function getLink(i) { return arrayImages[i].link; }
function getPath(i) { return arrayImages[i].path; }
function getWidth(i) { return arrayImages[i].width; }
function getHeight(i) { return arrayImages[i].height; }
</script>
<a id="anchor-0" href="" target="_blank">blah</a><br>
<a id="anchor-1" href="" target="_blank">blah</a><br>
</body></html>
[...]
--
Rob
Rob, thanks for your help!!! However, for some reason, the <body
onLoad="addAs();" is not finding the function! I added an alert to the
first line of the function addAs(), and the alert isn't firing. Any
idea on why it wouldn't be finding this function?
Thanks (again) in advance!
jason
RobG wrote: el**********@yahoo.com wrote: Hello! I was wondering if someone could help me out with a problem I'm having? I'm trying to input a javascript value into an anchor tag (from a function), but don't have an event to call the function...if that makes sense. Here's what I mean...
I have a javascript array set up like so:
<script language="javascript" TYPE="text/JavaScript">
//custom object constructor function theImage(path, width, height, link) { this.path = path; this.width = width; this.height = height; this.link = link; }
var arrayImages = new Array()
arrayImages[0] = new theImage("/somelink_a.jpg", "216", "302", "/somelink_b.jpg"); arrayImages[1] = new theImage(/anotherimage_a.jpg", "216", "302", "/anotherimage_b.jpg");
etc, etc...
And I have the following javascript functions...
function getLink(i) { var currentLink = arrayImages[i].link; return currentLink; }
Please don't post code with tabs, use 2 or four spaces for indents. These functions can be written like this:
function getLink(i) { return = arrayImages[i].link; }
[...] Now, for the HTML...
When I call these four functions through a body onLoad, like this:
<body class="background_color" onLoad="alert(getLink(1));alert(getPath(1));alert( getWidth(1));alert(getHeight(1));">
the values '/anotherimage_a.jpg"', '216', '302', '/anotherimage_b.jpg' are returned in the alert. But, I would like to have these values returned in an anchor tage like so...
<a href="javascript:getLink(1);" target="_blank"><img src="javascript:getPath(1);" width="javascript:getWidth(1);" height="javascript:getHeight(1);" border="0"><br>LARGER IMAGE</a>
This seems pretty futile, but I'll play along anyway. Presumably the A elements are in the HTML source and you want to use JavaScript to add properties. You could use the links collection, but it's likely you have other images in your document so you can use ID's. You could also give all the A elements you want to modify the same name and then use getElementsByName, the following example uses IDs.
Give all your A elements an id like "anchor-1", "anchor-2", etc.:
<html><head><title>blah</title> </head><body onload="addAs();"> <script type="text/javascript">
function theImage(path, width, height, link) { this.path = path; this.width = width; this.height = height; this.link = link; }
var arrayImages = []; arrayImages[0] = new theImage("a.jpg", "216", "302","a.jpg"); arrayImages[1] = new theImage("a.jpg", "216", "302","a.jpg");
function addAs() { if ( !document.getElementById || !document.createElement || !arrayImages ) { return; } var x, i, j=arrayImages.length; for ( i=0; i<j; i++ ){ x = document.getElementById('anchor-'+i); if ( x ) { x.href = getLink(i); var oImg = document.createElement('img'); oImg.src = getPath(i); oImg.width = getWidth(i); oImg.height = getHeight(i); oImg.alt = 'Sunset over the Outer Barcoo (where fences are few)'; x.appendChild(oImg); } } }
function getLink(i) { return arrayImages[i].link; }
function getPath(i) { return arrayImages[i].path; }
function getWidth(i) { return arrayImages[i].width; }
function getHeight(i) { return arrayImages[i].height; }
</script> <a id="anchor-0" href="" target="_blank">blah</a><br> <a id="anchor-1" href="" target="_blank">blah</a><br> </body></html>
[...]
-- Rob
Actually, I finally got this thing to fire, however, the snippet x =
document.getElementById('ancho*r-'+i); is NULL. Any idea why it's
null? What value should it be showing in x?
Thanks in advance!
"scooter" <el**********@yahoo.com> writes: Actually, I finally got this thing to fire, however, the snippet x = document.getElementById('ancho*r-'+i); is NULL. Any idea why it's null?
I haven't read the rest of the thread, but ID's may not contain the
character "-", so no matter what value "i" has, the resulting string
is not a valid id.
If the browser forgives you, and lets you use invalid strings for id's,
then you should still check that the document contains an element with
the id you are asking for.
/L
--
Lasse Reichstein Nielsen - lr*@hotpop.com
DHTML Death Colors: <URL:http://www.infimum.dk/HTML/rasterTriangleDOM.html>
'Faith without judgement merely degrades the spirit divine.'
Lasse Reichstein Nielsen wrote: "scooter" <el**********@yahoo.com> writes:
Actually, I finally got this thing to fire, however, the snippet x = document.getElementById('ancho*r-'+i); is NULL. Any idea why it's null?
No. I tested the code in Safari & Firefox on Mac before posting, I've
now checked in Firefox and IE for Windows. The only issue seems to be
that Firefox on Windows does not display the images - I can't set the
image element's src attribute (either directly or using setAttribute).
But clicking on the image placeholders shows a new window with the
image. Go figure - I haven't sorted an answer to this one yet.
I haven't read the rest of the thread, but ID's may not contain the character "-", so no matter what value "i" has, the resulting string is not a valid id.
<URL:http://www.w3.org/TR/html4/types.html#type-name>
The above section of the HTML spec says:
"ID and NAME tokens must begin with a letter ([A-Za-z]) and may be
followed by any number of letters, digits ([0-9]), hyphens ("-"),
underscores ("_"), colons (":"), and periods (".")."
which seems to indicate that hyphens are OK, but I've misread the spec
before :-(
The hyphen isn't really necessary, it can be removed or replaced with
an underscore if required. If the browser forgives you, and lets you use invalid strings for id's, then you should still check that the document contains an element with the id you are asking for.
/L
--
Rob This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics
by: bigbinc |
last post by:
set scroll position in javascript.
Is there a way to do this without using document.location, example.
document.location = "#gohere"
<a name="gohere">
|
by: Christian Radermacher |
last post by:
Hi,
the following code has the mentioned behaviour:
<html>
<head>
<script type="text/javascript">
function newA() {
for (i=0;i<3;i++) {
var a = window.frames.document.createElement("a");
|
by: Astra |
last post by:
Hi everybody
Wonder if you could help me out.
I created a simple JavaScript routine to enable a user to click backwards
and forwards between small news articles. This routine works fine in IE...
|
by: Simula |
last post by:
I am developing an HTML javascript application and I want to preserve
state in a way that can be book-marked. I chose HTML anchors as a means
of preserving state. When the application changes...
|
by: umamy |
last post by:
Hi, I am writing code to do the followin:
- user clicks a link
- the page reloads and sets a cookie with a js function in the header. The function reloads the same page with the cookie set and...
|
by: srini.venkatesan |
last post by:
I am trying to call a javascript from Datagrid which is using
OnUpdatecommand, I dont see update being invoked, what am I missing, Is
it the right way to call. I have just cut and pasted only the...
|
by: wavedancer |
last post by:
I just tried validating the page I'm working on as
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
and it fails on the PayPal...
|
by: k.j.stellema |
last post by:
I wonder if this is possible.. i have a couple of anchors inside a
page and all have 'pretty' URLs in the form of 'foo/bar/' and 'foo/
béar/'. If the user clicks on such an anchor (they are...
|
by: ravitunk |
last post by:
hi..i have a javascript function which uses window.open() function to open another window... as below...
<script language ="JavaScript">
function openWin(url)
{
...
|
by: ryjfgjl |
last post by:
ExcelToDatabase: batch import excel into database automatically...
|
by: isladogs |
last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM).
In this month's session, we are pleased to welcome back...
|
by: isladogs |
last post by:
The next Access Europe meeting will be on Wednesday 6 Mar 2024 starting at 18:00 UK time (6PM UTC) and finishing at about 19:15 (7.15PM).
In this month's session, we are pleased to welcome back...
|
by: Vimpel783 |
last post by:
Hello!
Guys, I found this code on the Internet, but I need to modify it a little. It works well, the problem is this: Data is sent from only one cell, in this case B5, but it is necessary that data...
|
by: PapaRatzi |
last post by:
Hello,
I am teaching myself MS Access forms design and Visual Basic. I've created a table to capture a list of Top 30 singles and forms to capture new entries. The final step is a form (unbound)...
|
by: Shællîpôpï 09 |
last post by:
If u are using a keypad phone, how do u turn on JavaScript, to access features like WhatsApp, Facebook, Instagram....
|
by: af34tf |
last post by:
Hi Guys, I have a domain whose name is BytesLimited.com, and I want to sell it. Does anyone know about platforms that allow me to list my domain in auction for free. Thank you
|
by: Faith0G |
last post by:
I am starting a new it consulting business and it's been a while since I setup a new website. Is wordpress still the best web based software for hosting a 5 page website? The webpages will be...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 3 Apr 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 former...
| |