Javascript error in firefox

Anandhi1
Anandhi1 used Ask the Experts™
on
Hi,

I have a jsp page that invokes the dateTimePicker calendar javascript. I have uploaded the javascript file. The line 'exDateTime=document.getElementById(pCtrl).value' is erroring out in the Firefox browser but not in any of the other browsers. Can you please help.
thanks,
Anu Calendar.js
Comment
Watch Question

Do more with

Expert Office
EXPERT OFFICE® is a registered trademark of EXPERTS EXCHANGE®
leakim971Multitechnician
Top Expert 2014

Commented:
put the code inside initializing the calendar inside :

window.onload = function() {
     // put INIT ONLY here
}

or use an other plugin :
http://www.ama3.com/anytime/
http://jqueryui.com/demos/datepicker/

Zvonko זְאֵבSystems architect
Top Expert 2006

Commented:
Show your line where you call that function NewCal()

Author

Commented:
Here is my code in the jsp where I am calling the function NewCal()

<netui:image src="/resources/images/cal.GIF"
                                    onClick="javascript:NewCal([getNetuiTagName('dateObserved', this)],'MMddyyyy',false,24);" tagId="calendar" />
Ensure you’re charging the right price for your IT

Do you wonder if your IT business is truly profitable or if you should raise your prices? Learn how to calculate your overhead burden using our free interactive tool and use it to determine the right price for your IT services. Start calculating Now!

Zvonko זְאֵבSystems architect
Top Expert 2006

Commented:
As far as I see it should be without squere braces:

<netui:image src="/resources/images/cal.GIF"
                                    onClick="javascript:NewCal(getNetuiTagName('dateObserved', this),'MMddyyyy',false,24);" tagId="calendar" />

You can do a check like this;

<netui:image src="/resources/images/cal.GIF"
                                    onClick="javascript:prompt('id',getNetuiTagName('dateObserved', this));NewCal([getNetuiTagName('dateObserved', this)],'MMddyyyy',false,24);" tagId="calendar" />

Afterwards look into browser page html source for that prompted id.

Author

Commented:
I found out where the problem was.
The  getElementID() was null in firefox. So when value method was called on that it caused the error.
I had to change it to the following code.
document[getNetuiTagName("formName", scope)][getNetuiTagName("elementId", scope)]

But now I am stuck at this point. When the user clicks on the calendar icon, the calendar displays but it does not select the value.

The code where it is errorring is here.
<a href=\"javascript:winMain.document.getElementById('"+Cal.Ctrl+"').value='"

The message in the error console says that winMain.document.getElementById("portlet_1_2{actionform.date}") is null.  

Can someone please help?

thanks,
Anu

leakim971Multitechnician
Top Expert 2014

Commented:
yes if you provide a link to see the page

Author

Commented:
When the user clicks on a date on the calendar, the date is populated in the field in the jsp page.
This works fine in the IE browser. But in the Firefox it gives the error that winMain.document.getElementById("portlet_1_2{actionform.date}") is null.  

I believe the value 'portlet_1_2{actionform.date}' is the field from the jsp.

I am using netui tags in the jsp.
When I am using the regular html tags, this works perfectly fine.

I am not sure which page you would like to see. I have already uploaded the javascript file.
I am pasting below the part of the code in the jsp where we invoke the javascript function.

<tr>
                                <td width="250"> Date situation was observed ** </td>
                                <td colspan="3">
                                <netui:textBox dataSource="actionForm.date" tagId="dateObserved"/>
                                <netui:image src="/resources/images/cal.GIF"
                                                      onClick="javascript:NewCal(getNetuiTagName('dateObserved', this),'MMddyyyy',false,24);" tagId="calendar" />
                                         
                                </td>
                            </tr>



leakim971Multitechnician
Top Expert 2014

Commented:
check this page : http://www.w3schools.com/tags/att_standard_id.asp

Naming rules:

Must begin with a letter A-Z or a-z
Can be followed by: letters (A-Za-z), digits (0-9), hyphens ("-"), underscores ("_"), colons (":"), and periods (".")
Values are case-sensitive


portlet_1_2{actionform.date}

just a thought...

Author

Commented:
Thanks for pointing out.

It may not recognize the curly braces  { }. But the value 'portlet_1_2{actionform.date} is generated by the weblogic portal.  
Commented:
The solution is found for this problem.
<a href=\"javascript:winMain.document.getElementById('"+Cal.Ctrl+"').value
is rewritten as
<a href=\"javascript:winMain.document.getElementById('"+"dateObserved"+"').value

where var dateObserved = document[getNetuiTagName("formName", scope)][getNetuiTagName("elementId", scope)]


Now this works in both IE and Firefox

thanks

Author

Commented:
I found this solution from other sources

Do more with

Expert Office
Submit tech questions to Ask the Experts™ at any time to receive solutions, advice, and new ideas from leading industry professionals.

Start 7-Day Free Trial