Solved

Javascript converting "null" to string

Posted on 2009-05-07
8
3,965 Views
Last Modified: 2012-05-06
I'm working on a Javascript program and I'm trying to figure out the best way to do the following:
I have a string and I want to concatenate it with another variable. The problem is that if the other variable is null, what I wind up with is my first string concatenated with the word "null". Instead, I want to have my first string concatenated with an empty string. Is there any way to change the default Javascript behavior, maybe by changing the toString function or something in String.prototype, so that "casting" a null to a String results in an empty string? Thanks.
var o = { a: 'string', b: null }

document.writeln(o.a + o.b);                     // prints "stringnull", i want it to just print "string"

Open in new window

0
Comment
Question by:tjgquicken
8 Comments
 
LVL 1

Expert Comment

by:secondeff
ID: 24326913
Hi,
What happens if you try using '' instead of null? {a: 'string' , b: ''}
0
 
LVL 12

Expert Comment

by:alien109
ID: 24326984
document.writeln(o.a + ((o.b)?o.b:""));
0
 
LVL 12

Expert Comment

by:Gibu George
ID: 24326994
var o = { a: 'string', b: null };
document.write((o.a==null)?'':o.a+(o.b==null)?'':o.b)
0
 
LVL 10

Accepted Solution

by:
bugada earned 125 total points
ID: 24327084
var o = { a: 'a', b: null };
document.write((o.a || '') + (o.b || ''));
0
Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

 

Author Comment

by:tjgquicken
ID: 24327686
Bugada probably has the most efficient solution, but I guess that having to check every variable for being null before I use it is just something I'm going to have to get used to in Javascript.
0
 

Author Comment

by:tjgquicken
ID: 24327744
Still I noticed the following:

new String() initializes an empty string
new String(null) initializes the character string "null"
new String(undefined) initializes the character string "undefined"
delete c; new String(c); throws a ReferenceError because c is not defined

There doesn't seem like a lot of logic to this behavior.
0
 
LVL 10

Expert Comment

by:bugada
ID: 24327837
No the behavior is coherent to javascript specifications.

null and undefined are reserved words with a special meaning so if you pass it in the string constructor  it creates an object with these values. This strings print their literal value as output, but you can't do normal operation on them on them, for example a substring.

The default String constructor creates an empty string.

The last line is correct because every variable used must be declared in its context, although most browsers initialize undeclared variable as undefined under the window contex. IE is very strict on this issue.
0
 

Author Comment

by:tjgquicken
ID: 24327876
Ok, that makes a lot more sense.
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction HTML checkboxes provide the perfect way for a web developer to receive client input when the client's options might be none, one or many.  But the PHP code for processing the checkboxes can be confusing at first.  What if a checkbox is…
Nothing in an HTTP request can be trusted, including HTTP headers and form data.  A form token is a tool that can be used to guard against request forgeries (CSRF).  This article shows an improved approach to form tokens, making it more difficult to…
The viewer will learn the basics of jQuery, including how to invoke it on a web page. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery.: (CODE)
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

895 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

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now