0

2つのページがあり、1つはメインページで、もう1つは内部ページです。

ページ名:main.jsp、sidebar.jspこれらの両方のページでonload関数を呼び出したいと思います。それは可能ですか。はいの場合どのように?

以下はmain.jspのコードです。

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@ include file="/pages/common/init.jsp"%>

<%@ taglib prefix="sx" uri="/struts-dojo-tags"%>

<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
    <title>J.C. Taylor - Broker Website</title>
    <meta http-equiv="content-type" content="text/html;charset=utf-8" />
    <link rel="stylesheet" href="/css/default.css" media="screen" type="text/css" />
</head>
<body onload="prepopulateFields();load(17);">

<s:form name="continue" id="continue_id" action="continue" method="POST"  validate="true" enctype="multipart/form-data">
    <div id="wrapper">
        <div id="main">
                <div id="sidebar">
                    <%@ include file="/pages/common/sidebar.jsp"%>
                    <span class="clearIt"></span>
                </div>

sidebar.jspは次のとおりです。

<body onload="setSelected();">
 //Some static content here
</body>

したがって、基本的には、メインの.jspページのonload()イベントに属するprepopulateFields()Javascriptメソッドと、sidebar.jspのonload()メソッドに属するsetSelected()を同時に個別に呼び出す必要があります。

setSelected();を呼び出すことができることはわかっています。prepopulateFields()メソッド内のメソッドですが、やりたくないです。私が欲しいのは、ページがロードされたときに、両方のonload関数を別々に呼び出す必要があることです。

何か提案があれば教えてください!私はここで少しばかげていることを知っていますが、それができれば私の仕事はとても簡単になります。

4

5 に答える 5

1

複数のonload関数を呼び出すことはできないと思います。最良の方法は、すでに呼び出されている関数からメソッドを呼び出すことです

function prepopulateFields(){
    if //condition which check the current page where you want other onload function
       setSelected();
}

<body onload="prepopulateFields();load(17);">



</body>
于 2010-06-05T04:26:40.330 に答える
0

<body>HTML要素をネストすることはできません。HTMLの形式が正しくないだけです。

<script>下部に置くのが最善ですsidebar.jsp

<script type="text/javascript">setSelected()</script>
于 2010-06-04T23:12:48.040 に答える
0

firebugを使用して、main.jspのレンダリングされたhtmlページを検査する場合。<body>要素が1つしかないことがわかります。sidebar.jspの<body>要素は、 HTMLをhtmlまたは含まれているjspで許可されていないbodyとして不正な形式にするため、レンダリングされません。

Be careful that the included file does not contain <html>, </html>, <body>, or </body> tags

解決策は次のとおりです。

  1. sidebar.jspが常にロードされている場合は、setSelected()をmain.jspbodyonloadイベントに入れます。
  2. またはBalusCが提案したように実行します。
于 2012-08-16T20:42:39.507 に答える
0

window.onload = codeAddress; 動作するはずです。これがデモです。そして完全なコード:

<script type="text/javascript">
function codeAddress() {
    alert('ok');
}
window.onload = codeAddress;
</script>
于 2013-02-08T17:37:52.450 に答える
0

クラス定義を親jspに配置し、インクルードで必要な数のオンロードをインスタンス化します。

<SCRIPT>
    // this portion was placed above the Class definition for convenience.
    // make sure the Class definition gets loaded first in your code.

    new OnLoad(function(){
        alert("document loaded");
    },100);

</SCRIPT>
...
<SCRIPT>
        // Class Definition
        OnLoad = function(taskFunction,miliseconds) { 
            var context = this;
            context.cnt = 0;
            context.id = null;
            context.doTask=taskFunction;
            context.interval = function() {
                if(document.readyState == "complete"){
                    try{   context.stop();} catch(e){ throw new Error("stop error: " + context.id); }
                    try{ context.doTask();} catch(e){ throw new Error("load error: " + context.id); }
                }   
            };
            context.start = function(timing) {
               if(context.id && context.id!=null)
                   context.stop();
               context.cnt=0;
               context.id=setInterval(context.interval,timing);
            };
            context.stop = function() {
               var _id = context.id;
               clearInterval(context.id);
               context.id=null;
            };
            context.start(miliseconds ? miliseconds : 100);
        };
   </SCRIPT>
于 2014-04-11T18:36:51.983 に答える