?
Solved

where is a javascript object defined

Posted on 2012-03-22
12
Medium Priority
?
238 Views
Last Modified: 2012-03-23
I'm maintaining an application. In a javascript .js file, the code below, I'm tracing and trying to find what GetDetails does. But I cannot find where ObjName is defined in any javascript file. I found a class definiation with the same name ObjName defined in a .cs file. I'm confused. .cs file runs on server. Where can I find the place defines ObjName?

Thanks. I know it is a basic question.
 
function myfunction()
{
    if (document.getElementById(ddlDropdown).value != '') {
        document.getElementById(fld1).value = document.getElementById(ddlDropdown).value;
        ObjName.GetDetails(document.getElementById(fld1).value, DoSomething, Onfailure);
    }
}
0
Comment
Question by:minglelinch
  • 6
  • 6
12 Comments
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37754293
use firebug to debug this script, i hope you are aware of it.
Anyways, here is a link to it...
http://www.evotech.net/blog/2007/06/introduction-to-firebug/

there must be a prototype with GetDetails Function in it.
If there is no such prototype, probably this is not the right code....
0
 
LVL 1

Author Comment

by:minglelinch
ID: 37754510
Yes, I found prototype while I'm debug it. I also find the GetDetails is a C# function of ObjName class in ObjName.cs file. This is my first time for the concept prototype in .net development. Is it a connect for javascript and web methord? web service? Could you please give more about it? Thank you.
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37754561
prototypes are basically classes in Javascripts which are converted to objects.
This method should be in JS, how can you call a method in cs from within JS since JS is client side script and CS is server side.

Use Firebug to debug and see...
0
Get your problem seen by more experts

Be seen. Boost your question’s priority for more expert views and faster solutions

 
LVL 1

Author Comment

by:minglelinch
ID: 37754657
Thank you a lot.

It's said Firebug works with Firefox. I'm using IE. At this time kind of wondering ...

Where or how to create protype?
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37754683
0
 
LVL 1

Author Comment

by:minglelinch
ID: 37754999
Nice link and thanks for your direction. Let me ask a further question please.

While I'm debuging to the above code, I was brought to jsdebug [dynamic] which contains the following code:

var ObjName=function() {
ObjName.initializeBase(this);
this._timeout = 0;
this._userContext = null;
this._succeeded = null;
this._failed = null;
}
ObjName.prototype={
_get_path:function() {
 var p = this.get_path();
 if (p) return p;
 else return Address._staticInstance.get_path();},
... ...
... ...

GetDetails:function(address,succeededCallback, failedCallback, userContext) {
/// <param name="address" type="String">System.String</param>
/// <param name="succeededCallback" type="Function" optional="true" mayBeNull="true"></param>
/// <param name="failedCallback" type="Function" optional="true" mayBeNull="true"></param>
/// <param name="userContext" optional="true" mayBeNull="true"></param>
return this._invoke(this._get_path(), 'GetDetails',false,{address:address},succeededCallback,failedCallback,userContext); },


It seems like the place where defines the prototype and the method. But it's like generated dynamically. No other places where I can find the method definition, which lead me think that the prototype is generated by some modul creation. But how is here?

Thanks.
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37755815
these are the classes used by firebug to enable debugging.
This is where the debug symbols are loaded by, has got nothing to do with your code....
0
 
LVL 1

Author Comment

by:minglelinch
ID: 37757429
Thanks. I debug it again. ((ObjName is Address)
)

I set break point to
ObjName .GetDetails(document.getElementById(fld1).value, DoSomething, Onfailure);

then execution jump to
ObjName ._staticInstance.GetDetails(address,onSuccess,onFailed,userContext); }
then to
return this._invoke(this._get_path(), 'GetDetails',false,{address:address},succeededCallback,failedCallback,userContext);
then to
ObjName .prototype={
_get_path:function() {
 var p = this.get_path();
 if (p) return p;
 else return Address._staticInstance.get_path();},
then to
return Sys.Net.WebServiceProxy.invoke(d,e,g,f,c,b,a,this.get_timeout())
......
var b=new Sys.Net.WebRequest
... ...
var d=Sys.Net.WebRequest._createQueryString(b) ...

The javascript function is added by
ddlboxname.Attributes.Add("onchange", "myfunction();return false;");


Except GetDetails method in ObjName.cs, there's no GetDetails function in the whole project. GetDetails method in ObjName.cs does the expected work for onchange event, btu this is on the server side.

How does all this work?

I know it is a mess question. May it is the point where my problem is.

Thanks.
0
 
LVL 20

Expert Comment

by:BuggyCoder
ID: 37758558
i think you are using ajax control library and scriptmanager, updatepanel etc...
0
 
LVL 1

Author Comment

by:minglelinch
ID: 37758686
Thanks for answering. Yes, I do use those. Does it matter?
0
 
LVL 20

Accepted Solution

by:
BuggyCoder earned 2000 total points
ID: 37758704
oh yes it does, there lies an answer to your question of how the server side method is bieng called in Js.

This is because it is a part of <asp:ScriptManager>
Read Here to see how it works:-
http://msdn.microsoft.com/en-us/magazine/cc163354.aspx
0
 
LVL 1

Author Closing Comment

by:minglelinch
ID: 37759321
Great answer, thank you.
0

Featured Post

Free Tool: Path Explorer

An intuitive utility to help find the CSS path to UI elements on a webpage. These paths are used frequently in a variety of front-end development and QA automation tasks.

One of a set of tools we're offering as a way of saying thank you for being a part of the community.

Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

The PowerShell Core 6.0 of .NET release is just the beginning. The upcoming PowerShell Core 6.1 would have artificial intelligence and internet of things capabilities. So many things to look forward to in the upcoming release.
Article by: Shaun
Tiling windows is a great way to see multiple applications at once. Windows Tiler is a tool that automatically tiles open application windows as the open and close.
The video will let you know the exact process to import OST/PST files to the cloud based Office 365 mailboxes. Using Kernel Import PST to Office 365 tool, one can quickly import numerous OST/PST files to Office 365. Besides this, the tool also comes…
In the video, one can understand the process of resizing images in single or bulk. Kernel Bulk Image Resizer is an easy to use tool for resizing large number of images. One can add and resize multiple images with this tool in single go. The video sh…

568 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question