Я в этой ситуации
index.html:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
<script type="text/javascript" src="mootools.js"></script>
<script>
window.addEvent('domready', function() {
var b=document.createElement('iframe');
b.src="about:blank";
b.style.height="0px";
b.style.width = "0px";
b.style.visibility="hidden";
b.style.border="none";
b.id = "my_frame";
b.src="about:blank";
var headID = document.getElementsByTagName("head")[0];
headID.appendChild(b);
var val = '<html><head>';
val += '<scr' + 'ipt type="text/javascript" src="test.class.js"></scr' + 'ipt>';
val += '</head><body></body></html>';
var doc = b.contentWindow || b.contentDocument;
if (doc.document){
doc = doc.document
}
doc.open();
doc.write(val);
doc.close();
});
</script>
</head>
<body>
<div id="main"></div>
<script>var a = new Test();</script>
<script>a.doSomething();</script>
</body>
</html>
test.class.js:
var Test = new Class({
doSomething: function(){
alert("ok!");
}
});
Возможно ли вставить класс Test в родительское окно, не используя что-то вроде parent.frames["my_frame"].func();
? Мне нужно использовать только этот способ для вызова класса:
<script>var a = new Test();</script>
<script>a.doSomething();</script>