zoukankan      html  css  js  c++  java
  • JS模块化工具requirejs教程(一):初识requirejs

    正常编写方式

    index.html:

    <!DOCTYPE html>
    <html>
        <head>
            <script type="text/javascript" src="a.js"></script>
        </head>
        <body>
          <span>body</span>
        </body>
    </html>

    a.js:

    function fun1(){
      alert("it works");
    }
    
    fun1();

    可能你更喜欢这样写

    (function(){
        function fun1(){
          alert("it works");
        }
    
        fun1();
    })()

    第二种方法使用了块作用域来申明function防止污染全局变量,本质还是一样的,当运行上面两种例子时不知道你是否注意到,alert执行的时候,html内容是一片空白的,即<span>body</span>并未被显示,当点击确定后,才出现,这就是JS阻塞浏览器渲染导致的结果。

    requirejs写法

    当然首先要到requirejs的网站去下载js -> requirejs.rog
    index.html:

    <!DOCTYPE html>
    <html>
        <head>
            <script type="text/javascript" src="require.js"></script>
            <script type="text/javascript">
                require(["a"]);
            </script>
        </head>
        <body>
          <span>body</span>
        </body>
    </html>

    a.js:

    define(function(){
        function fun1(){
          alert("it works");
        }
    
        fun1();
    })

    浏览器提示了"it works",说明运行正确,但是有一点不一样,这次浏览器并不是一片空白,body已经出现在页面中,目前为止可以知道requirejs具有如下优点:

    1. 防止js加载阻塞页面渲染
    2. 使用程序调用的方式加载js,防出现如下丑陋的场景
    <script type="text/javascript" src="a.js"></script>
    <script type="text/javascript" src="b.js"></script>
    <script type="text/javascript" src="c.js"></script>
    <script type="text/javascript" src="d.js"></script>
    <script type="text/javascript" src="e.js"></script>
    <script type="text/javascript" src="f.js"></script>
    <script type="text/javascript" src="g.js"></script>
    <script type="text/javascript" src="h.js"></script>
    <script type="text/javascript" src="i.js"></script>
    <script type="text/javascript" src="j.js"></script>

     

  • 相关阅读:
    ssh 无密码互通
    React之jsx转js
    分布式事务参考
    js跨域解决方案
    idea编译时JDK版本变化
    计数算法
    Rocketmq消息持久化
    rocketmq安装
    nginx高可用配置
    nginx负载均衡设置
  • 原文地址:https://www.cnblogs.com/xuan52rock/p/4727824.html
Copyright © 2011-2022 走看看