Invalid Character DOM Exception In IE9
Solution 2:
For jQuery.bgiframe.js, would be a better solution to fix the wrong IE6 test?
What about replacing this:
if($.browser.msie&&/6.0/.test(navigator.userAgent)
with something like this:
if ($.browser.msie && $.browser.version=="6.0")
Solution 3:
For jquery.bgiframe.js:
I downloaded version 1.1.3 pre at
https://github.com/brandonaaron/bgiframe/blob/master/jquery.bgiframe.js
and this solved the problem.
Solution 4:
This error can come when accidentally using standard JavaScript function names as your own function names if you don't use namespaces. For example I have a concept called "Attribute" and I wanted to try a new function that created a new one of those:
<button onclick="createAttribute('Pony')">Foo</button>
<button onclick="createAttribute('Magical pony')">Bar</button>
<script type="text/javascript">
function createAttribute(name) { alert(name); }
</script>
- Clicking "Foo" gives you nothing
- Clicking Foo gives you
INVALID_CHARACTER_ERR (5)
orInvalidCharacterError: DOM Exception 5
- Opening your dev console and running
createAttribute('Django')
gives you the alert
What is happening is that the buttons are calling document.createAttribute()
and your dev console is calling the function you declared.
Answer : use a different function name or better yet, a namespace.
Solution 5:
If you are willing to sacrifice a little performance and can use an external library I would suggest using:
Prototype JS
var el = new Element('iframe', {
id: "<your id here>",
src: "<your source here>",
style: "<your style here>"
});
jQuery
var el = jQuery('<iframe>', {
id: '<your id here>',
src: "<your source here>",
style: "<your style here>"
})[0];
This takes care of all the inconsistencies between browsers and is also a lot prettier :-)
Note: This is untested pseudocode - refer to the official documentation pages of Prototype JS and jQuery for more information.
Post a Comment for "Invalid Character DOM Exception In IE9"