2

ポップアップ ウィンドウを作成しましたが、その中で親ウィンドウで作成した関数を使用したいと考えています。window.opener.parentFunction() を使用してみましたが、役に立ちました。他の誰かがこの問題を経験しましたか? 私のコードは次のようになります。

function parentFunction(){
alert('testing');
}


function print(){
var new_win = window.open('','name','height=400,width=500');
var output = "<html><head></head><body><table>\n";


for (i = 0; i < 10; i++) {
output += "<td onclick='window.opener.parentFunction()'>"+i+"</td>";
}

output += "</table></body></html>\n";
new_win.document.write(output);
}

*動作しました。みんなありがとう。

4

1 に答える 1

4

あなたのコードにはたくさんの問題があります。ここに動作するデモをまとめました。

HTML

<button id="clickMe">Click me</button>

JavaScript

window.onload = function() {

    function parentFunction() {
        alert('testing');
    }

    window.parentFunction = parentFunction;

    var years = [1, 2, 3, 4, 5, 6];

    function print() {
        var new_win = window.open('', 'name', 'height=400,width=500');
        //var cols = this.getCols();
        var cols = 2;
        var output = "<html><head></head><body><table>";
        var cell_count = 1;
        for (i = 0; i < years.length; i++) {
            if (cell_count === 1) {
                output += "<tr>";
            }
            output += "<td onclick='window.opener.parentFunction();'>" + years[i] + "</td>";
            cell_count++;
            // end the row if we've generated the expected number of columns
            // or if we're at the end of the array
            if (cell_count > cols || i === years.length - 1) {
                output += "</tr>\n";
                cell_count = 1;
            }
        }
        output += "</table></body></html>";
        new_win.document.write(output);
    }

    document.getElementById('clickMe').onclick = print;
};
  • years定義されていませんでした
  • this.getCols()定義されていませんでした
  • parentFunctionwindowスコープでは(おそらく)見えなかった
于 2011-03-22T13:58:54.063 に答える