zoukankan      html  css  js  c++  java
  • Js文件中调用其它Js函数的方法

    在项目开发过程中,也许你会遇这样的情况。在某一Js文件中需要完成某一功能,但这一功能的大部分代码在另外一个Js文件中已经完成了,自己只需要调用这个方法再加上几句代码就可以实现所需的功能。我们知道,在html中,利用
    <script language="javascript" type="text/javascript" src="../script.js"></script>
    引入的两个js是不可以相互调用的。那么该如何解决呢?当然,你可以将代码通通copy过来,这样会让你的b.js会变得很长,也许已经影响到了你对b.js的定位了,检查,维护都会变得麻烦.
      例如有这样一个html,里面有一个按钮,当按下时调用b.js文件中的方法b()。而b()中又要调用a.js文件中的方法a()。那我们应该怎么做呢?
      首先,我们在html中引入b.js,并在</body>之后加入引用语句。必须注意,将要引入的Js文件代码放在</body>下面。

    <html>
      <body>
         <input type="button" value="ok" onclick="javascript:b()">
      </body>
     
     <!--这里引用要放在body下面-->
     <script language="JAVASCRIPT" src='b.js'></script>
     
    </html>
      b.js文件中引入a.js,内容如下:
    
    
     new_element=document.createElement("script");
     new_element.setAttribute("type","text/javascript");
    new_element.setAttribute("src","a.js");// 在这里引入了a.js
     document.body.appendChild(new_element);
     
     function b()  {
         a();
     }
    
    
      在b.js文件中前4行代码中我们引入了a.js文件,并在第7行代码中调用了a.js代码中的a()方法。

      让我们来分析一下关键的几句代码:首先,我们利用document.createElement("script")生成了一个script的标签,设置其type属性为text/javascript,src为a.js(这里的a.js同b.js放在同一个目录,也可放在不同的目录)。最后将这个标签动态地加入body中。如此一来,我们就可以调用到不同js文件中的方法了。

    注意:<script language="JAVASCRIPT" src='b.js'></script>一定要放在body下面。 
    因为在b.js中用到了body(document.body.appendChild(new_element);) 
    如果将引如b.js的代码放在body上面,也就是说, 
    进入页面后,还没有生成body就已经执行b.js里的document.body.appendChild(new_element);了。 
    这时body不存在就会抛javascript错误。

    原文出处:

    [1] jimshi, Js文件中调用其它Js函数的方法, https://www.cnblogs.com/shijingxiang/articles/4941790.html

  • 相关阅读:
    objective-c保护属性
    第十七章、程序管理与 SELinux 初探 工作管理 (job control)
    第十七章、程序管理与 SELinux 初探
    Shell运算符:Shell算数运算符、关系运算符、布尔运算符、字符串运算符等
    go语言初始化内部结构体3中方式
    数据结构之C语言模拟整数数组实现
    使用python将元组转换成列表,并替换其中元素
    ruby中的类实例变量和实例的实例变量
    读<<programming ruby>> 7.6节 flip-flop 理解
    ruby逻辑判断符号
  • 原文地址:https://www.cnblogs.com/ryelqy/p/10104051.html
Copyright © 2011-2022 走看看