Connecting Tech Pros Worldwide Help | Site Map

How to check if an object has defined setter?

  #1  
Old August 27th, 2008, 08:45 PM
Piotr K
Guest
 
Posts: n/a
Hi!

Ok, so I have small problem and can't find solution to it.. Is there
any way to check if an object has defined setter? In other words - if
it's value can be changed?

Small example:

var el = document.getElementById('element');

el.style = "smth";

Browser will throw exception, I can use try..catch but is there way to
just write a function like hasSetter() ?

Thanks fo help!
  #2  
Old August 27th, 2008, 10:25 PM
dhtml
Guest
 
Posts: n/a

re: How to check if an object has defined setter?


Piotr K wrote:
Quote:
Hi!
>
Ok, so I have small problem and can't find solution to it.. Is there
any way to check if an object has defined setter? In other words - if
it's value can be changed?
>
Small example:
>
var el = document.getElementById('element');
>
el.style = "smth";
>
Browser will throw exception, I can use try..catch but is there way to
just write a function like hasSetter() ?
>

To look up a setter in environments that support that:
if("__lookupSetter__" in el.style
&& el.style.__lookupSetter__("color")) {

}

But that would not tell you if the value can be changed, or what
acceptable values are. You'd just have to know it. For example, given el
is an HTMLElement:-

el.style.color = null;

Would be a mistake.

If there were edge cases that couldn't be eliminated, you could use
try/catch. But that would add clutter and slow the program down.


Garrett

  #3  
Old August 27th, 2008, 10:55 PM
Thomas 'PointedEars' Lahn
Guest
 
Posts: n/a

re: How to check if an object has defined setter?


Piotr K wrote:
Quote:
Ok, so I have small problem and can't find solution to it.. Is there
any way to check if an object has defined setter? In other words - if
it's value can be changed?
No, but you can test whether the value changed after you tried.
Quote:
Small example:
>
var el = document.getElementById('element');
>
el.style = "smth";
>
Browser will throw exception,
BAD. The `style' property of element objects is implemented as a reference
to an object, and its interface specifies it as being read-only.
Quote:
I can use try..catch but is there way to just write a function like
hasSetter() ?
No. Adhering to standards stands the best chance of not throwing an
exception here.

<http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-ElementCSSInlineStyle>


PointedEars
--
Prototype.js was written by people who don't know javascript for people
who don't know javascript. People who don't know javascript are not
the best source of advice on designing systems that use javascript.
-- Richard Cornford, cljs, <f806at$ail$1$8300dec7@news.demon.co.uk>
  #4  
Old August 28th, 2008, 11:15 AM
Laser Lips
Guest
 
Posts: n/a

re: How to check if an object has defined setter?


On Aug 27, 10:50 pm, Thomas 'PointedEars' Lahn <PointedE...@web.de>
wrote:
Quote:
Piotr K wrote:
Quote:
Ok, so I have small problem and can't find solution to it.. Is there
any way to check if an object has defined setter? In other words - if
it's value can be changed?
>
No, but you can test whether the value changed after you tried.
>
Quote:
Small example:
>
Quote:
var el = document.getElementById('element');
>
Quote:
el.style = "smth";
>
Quote:
Browser will throw exception,
>
BAD. The `style' property of element objects is implemented as a reference
to an object, and its interface specifies it as being read-only.
>
Quote:
I can use try..catch but is there way to just write a function like
hasSetter() ?
>
No. Adhering to standards stands the best chance of not throwing an
exception here.
>
<http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-ElementCSSInlineS...>
>
PointedEars
--
Prototype.js was written by people who don't know javascript for people
who don't know javascript. People who don't know javascript are not
the best source of advice on designing systems that use javascript.
-- Richard Cornford, cljs, <f806at$ail$1$8300d...@news.demon.co.uk>
Do what ever you need to try and do in a try and catch statement ...
e.g

var worked = false;
try
{
var el = document.getElementById('element');
el.style = "smth";
worked=true;
}catch(e)
{
//in here you can alert(e.message); or set an internal error message
}
if(worked==true)
{
//worked
}else{
//didnt work
}


Closed Thread


Similar Threads
Thread Thread Starter Forum Replies Last Post
Protected static members, abstract classes, object composition vs. subclassing Kevin Prichard answers 11 November 29th, 2005 01:45 AM
thread pooling and short lived threads AlexeiOst answers 31 November 22nd, 2005 03:14 PM
Externally-defined properties? Terry Hancock answers 3 August 25th, 2005 09:35 AM
thread pooling and short lived threads AlexeiOst answers 31 July 21st, 2005 07:20 PM