3

Why doesn't this work

<script src="jquery.js"/>

But this works

<script src="jquery.js"></script>

?

Firefox 3.5.8

2

2 Answers 2

7

Because:

<script src="jquery.js"/>

is valid XML (including XHTML) but is not valid HTML.

See 18.2.1 The SCRIPT element:

18.2.1 The SCRIPT element

<!ELEMENT SCRIPT - - %Script;          -- script statements -->
<!ATTLIST SCRIPT
  charset     %Charset;      #IMPLIED  -- char encoding of linked resource --
  type        %ContentType;  #REQUIRED -- content type of script language --
  src         %URI;          #IMPLIED  -- URI for an external script --
  defer       (defer)        #IMPLIED  -- UA may defer execution of script --
  >

Start tag: required, End tag: required

Sign up to request clarification or add additional context in comments.

2 Comments

will the /> trick work (in modern browsers) if the pages Content-Type header is application/xml? I've heard of such black magic before.
@jdizzle /> will work if its an XHTML document, which has several ramifications. It has problems with older browsers and (imho) there's no compelling reason to use XHTML so just don't do it would be my advice.
0

The script element is not defined as EMPTY (since you can embed the script directly inside it), therefore in HTML the end tag is required, therefore you cannot have something that is (in tag soup terms) a start tag with a random / character in it representing the entire element.

Hence we have: http://www.w3.org/TR/xhtml-media-types/#C_2

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.