Software, your way.
burger menu icon
WillMaster

WillMasterBlog > JavaScript

FREE! Coding tips, tricks, and treasures.

Possibilities weekly ezine

Get the weekly email website developers read:

 

Your email address

name@example.com
YES! Send Possibilities every week!

Inserting An External JavaScript File Into JavaScript

When attempting to use document.write() to insert an external JavaScript file into a web page, the </script> tag within the document.write() statement can spawn an error. (The action is sometimes called "nesting," as in nesting one command inside another.)

There is a work-around.

Let us suppose this is the original attempt:

<script type="text/javascript">
document.write('<script type="text/javascript" src="file.js"></script>');
</script>

What happens is that the </script> tag in the document.write() closes the JavaScript code block. That spawns an error because the document.write() command wasn't properly closed first.

Yet, that </script> tag must be there in order to close the nested script tag.

Here is the workaround.

<script type="text/javascript"><!--
document.write('<scr' + 'ipt type="text/javascript" src="file.js"></scr' + 'ipt>');
//--></script>

Notice that the word "script" was replaced with "scr' + 'ipt" in both places. In that way, the complete word "script" is nowhere in the JavaScript. Yet, when the code runs, the words will be concatenated correctly.

Both the tag and the closing tag were changed to "scr' + 'ipt" to remove any ambiguity any browser might find. The code then runs as expected.

Edit (8 days after original publication): The HTML comment tag to hide the document.write() line from non-JavaScript browsers was added because at least one XHTML validator tries to validate JavaScript. And it protests what it misinterprest as broken tags: <scr'+'ipt... and </scr'+'ipt>

Will Bontrager

Was this blog post helpful to you?
(anonymous form)

Support This Website

Some of our support is from people like you who see the value of all that's offered for FREE at this website.

"Yes, let me contribute."

Amount (USD):

Tap to Choose
Contribution
Method


All information in WillMaster Blog articles is presented AS-IS.

We only suggest and recommend what we believe is of value. As remuneration for the time and research involved to provide quality links, we generally use affiliate links when we can. Whenever we link to something not our own, you should assume they are affiliate links or that we benefit in some way.

Recent Articles in the Library

Form Debugging Assistant

Form Debugging Assistant is a handy tool. If you keep the JavaScript in a file on your server, it can be pulled into a web page whenever you need to debug a form.

Make Smaller Copy of Image

The MakeSmallerCopyOfImage function can be placed into your PHP scripts. It is designed to make a copy of an image and reduce its size.

Tap to Select

Making it easy for your site visitors to select content they probably will want to copy is a gesture of friendliness.

CSV to HTML Table

Create an HTML table from a CSV file.

Image Transparency

An image can be given a degree of transparency with the CSS opacity property.

Finding Div's Top-Left Corner Position

The coordinates of any type of HTML element can be determined.

Silent Notes

Once implemented, this system is a nice logger when occurrences of extra-important events on a web page need to be counted.

How Can We Help You? balloons
How Can We Help You?
bullet Custom Programming
bullet Ready-Made Software
bullet Technical Support
bullet Possibilities Newsletter
bullet Website "How-To" Info
bullet Useful Information List

© 1998-2001 William and Mari Bontrager
© 2001-2011 Bontrager Connection, LLC
© 2011-2025 Will Bontrager Software LLC