<bdo id='yMlNf'></bdo><ul id='yMlNf'></ul>

      <i id='yMlNf'><tr id='yMlNf'><dt id='yMlNf'><q id='yMlNf'><span id='yMlNf'><b id='yMlNf'><form id='yMlNf'><ins id='yMlNf'></ins><ul id='yMlNf'></ul><sub id='yMlNf'></sub></form><legend id='yMlNf'></legend><bdo id='yMlNf'><pre id='yMlNf'><center id='yMlNf'></center></pre></bdo></b><th id='yMlNf'></th></span></q></dt></tr></i><div id='yMlNf'><tfoot id='yMlNf'></tfoot><dl id='yMlNf'><fieldset id='yMlNf'></fieldset></dl></div>

        <small id='yMlNf'></small><noframes id='yMlNf'>

      1. <legend id='yMlNf'><style id='yMlNf'><dir id='yMlNf'><q id='yMlNf'></q></dir></style></legend>

        <tfoot id='yMlNf'></tfoot>

        Javascript,从开启器调用子窗口函数不起作用

        Javascript,calling child window function from opener doesn#39;t work(Javascript,从开启器调用子窗口函数不起作用)

          <tbody id='GbxLy'></tbody>
            <tfoot id='GbxLy'></tfoot>

            <small id='GbxLy'></small><noframes id='GbxLy'>

          1. <legend id='GbxLy'><style id='GbxLy'><dir id='GbxLy'><q id='GbxLy'></q></dir></style></legend>
            <i id='GbxLy'><tr id='GbxLy'><dt id='GbxLy'><q id='GbxLy'><span id='GbxLy'><b id='GbxLy'><form id='GbxLy'><ins id='GbxLy'></ins><ul id='GbxLy'></ul><sub id='GbxLy'></sub></form><legend id='GbxLy'></legend><bdo id='GbxLy'><pre id='GbxLy'><center id='GbxLy'></center></pre></bdo></b><th id='GbxLy'></th></span></q></dt></tr></i><div id='GbxLy'><tfoot id='GbxLy'></tfoot><dl id='GbxLy'><fieldset id='GbxLy'></fieldset></dl></div>

              • <bdo id='GbxLy'></bdo><ul id='GbxLy'></ul>

                  本文介绍了Javascript,从开启器调用子窗口函数不起作用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

                  问题描述

                  我正在开发一个使用 windows.open(..) 打开弹出窗口的 Web 应用程序.我需要使用window.open"返回的句柄在打开的窗口上调用一个函数,但我总是收到错误消息addWindow.getMaskElements is not a function",好像它无法访问声明的函数在子窗口上.这是 IE 和 FF 中的行为.我的代码如下所示:

                  I'm developing a web application that opens a popup using windows.open(..). I need to call a function on the opened window using the handle returned by "window.open", but I'm always getting the error message "addWindow.getMaskElements is not a function", as if it couldn't access the function declared on child window. This is the behavior in both IE and FF. My code looks like this:

                  function AddEmail(target,category)
                  {
                      if(addWindow == null)
                      {
                          currentCategory = category;
                          var left = getDialogPos(400,220)[0];
                          var top =  getDialogPos(400,220)[1];
                          addWindow = window.open("adicionar_email.htm",null,"height=220px, width=400px, status=no, resizable=no");
                          addWindow.moveTo(left,top);
                          addWindow.getMaskElements ();
                      }
                  }
                  

                  我已经用谷歌搜索并阅读了不同的可靠来源,显然这应该有效,但它没有.另一件事是,子窗口中的函数在 adicionar_email.htm 文件中包含的单独 .js 文件中声明.这有什么不同吗?不应该..所以,如果有人遇到过类似的问题,或者知道我做错了什么,请回复此消息.提前致谢.

                  I've googled and read from different reliable sources and apparently this is supposed to work, however it doesn't. One more thing, the functions in child window are declared in a separate .js file that is included in the adicionar_email.htm file. Does this make a difference? It shouldn't.. So, if anyone has ran into a similar problem, or has any idea of what I'm doing wrong, please, reply to this message. Thanks in advance.

                  肯尼亚

                  推荐答案

                  窗口创建不是阻塞操作;脚本在该窗口打开并加载 HTML & 时继续执行javascript并解析它.

                  The window creation is not a blocking operation; the script continues to execute while that window is opening and loading the HTML & javascript and parsing it.

                  如果您要在原始页面上添加这样的链接:

                  If you were to add a link on your original page like this:

                  <a href="#" onclick="addWindow.getMaskElements();">Test</a>
                  

                  你会看到它有效.(我试了一下只是为了确定.)

                  You'd see it works. (I tried it just to be sure.)

                  **编辑**

                  其他人通过在目标文档中调用 onload 发布了解决方法,这是另一种方法:

                  Someone else posted a workaround by calling an onload in the target document, here's another approach:

                  function AddEmail()
                  {
                  
                          if(addWindow == null) {
                          addWindow = window.open("test2.html",null,"height=220px, width=400px, status=no, resizable=no");
                          }
                  
                          if(!addWindow.myRemoteFunction) {
                              setTimeout(AddEmail,1000);
                          } else { addWindow.myRemoteFunction(); }
                  }
                  

                  这会一直尝试每 1 秒调用一次 addWindow.myRemoteFunction,直到成功调用它.

                  This keeps trying to call addWindow.myRemoteFunction every 1 second til it manages to sucessfully call it.

                  这篇关于Javascript,从开启器调用子窗口函数不起作用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Fetch multiple links inside foreach loop(在 foreach 循环中获取多个链接)
                  Backbone Fetch Request is OPTIONS method(Backbone Fetch Request 是 OPTIONS 方法)
                  Fetch API leaks memory in Chrome(Fetch API 在 Chrome 中泄漏内存)
                  How can I download and save a file using the Fetch API? (Node.js)(如何使用 Fetch API 下载和保存文件?(Node.js))
                  Send blob data to node using fetch, multer, express(使用 fetch、multer、express 将 blob 数据发送到节点)
                  Sending a custom User-Agent string along with my headers (fetch)(发送自定义用户代理字符串以及我的标头(获取))
                1. <i id='vS6tn'><tr id='vS6tn'><dt id='vS6tn'><q id='vS6tn'><span id='vS6tn'><b id='vS6tn'><form id='vS6tn'><ins id='vS6tn'></ins><ul id='vS6tn'></ul><sub id='vS6tn'></sub></form><legend id='vS6tn'></legend><bdo id='vS6tn'><pre id='vS6tn'><center id='vS6tn'></center></pre></bdo></b><th id='vS6tn'></th></span></q></dt></tr></i><div id='vS6tn'><tfoot id='vS6tn'></tfoot><dl id='vS6tn'><fieldset id='vS6tn'></fieldset></dl></div>
                    <bdo id='vS6tn'></bdo><ul id='vS6tn'></ul>

                      <tbody id='vS6tn'></tbody>
                      • <small id='vS6tn'></small><noframes id='vS6tn'>

                          <legend id='vS6tn'><style id='vS6tn'><dir id='vS6tn'><q id='vS6tn'></q></dir></style></legend>

                          1. <tfoot id='vS6tn'></tfoot>