Is there any difference between
<input type="submit" value="Register" onclick="javascript:submitTheForm();">
and
<input type="submit" value="Register" onclick="submitTheForm();">
Should I use javascript:
before a JS function call?
Is there any difference between
<input type="submit" value="Register" onclick="javascript:submitTheForm();">
and
<input type="submit" value="Register" onclick="submitTheForm();">
Should I use javascript:
before a JS function call?
javascript:
inside an onwhatever=""
handler is a no-op. The content of this attribute is always JavaScript so javascript:
defines a label - but outside of a switch
block or a loop (where you can use it to break
/continue
to the position of the label) it does nothing.
However, using inline event handlers is discouraged, there are better ways to register event handlers.
While not mentioned in the question, it's worth noting that using javascript:
in the href
attribute does work (and in there it is actually necessary) but is highly discouraged for various reasons:
this
does not point to the elementSo, if you really have to use inline events, always use onclick=""
etc. without javascript:
.
When you are in a onclick
attribute, you shouldn't use the javascript:
prefix. This is usefull when you want a link <a />
to handle a JS function, for example:
<a href="javascript:myfunc();"></a>
javascript:func()
is using the javascript protocol so that it could be used in an anchors href
attribute. However, don't do this see Why is it bad practice to use links with the javascript: “protocol”? for more information.
Event handlers are preferable to trigger events instead of attributes.