初识JS模块化工具RequireJS

RequireJS是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一。最新版本的RequireJS压缩后只有14K,堪称非常轻量。它还同时可以和其他的框架协同工作,使用RequireJS必将使您的前端代码质量得以提升。

RequireJS会让你以不同于往常的方式去写JavaScript。你将不再使用script标签在HTML中引入JS文件,以及不用通过script标签顺序去管理依赖关系。当然也不会有阻塞(blocking)的情况发生。
先来看一段常见的场景,通过示例讲解如何运用requirejs

正常编写方式

test.html


<html>
    <head>
        <title>浅尝JS模块化工具RequireJStitle>
        <script type="text/javascript" src="hello.js">script>
    head>
    <body>
      <span>this is bodyspan>
    body>
html>

hello.js

function sayhello() {
    alert('hello world!');
}
sayhello();

或者是这样的

(function() {
    function sayhello() {
    alert('hello world!');
    }
    sayhello();
})();

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

requirejs写法

test.html


<html>
    <head>
        <title>浅尝JS模块化工具RequireJStitle>
        <script type="text/javascript" src="require.js">script>
        <script type="text/javascript">
            require(["hello"]);
        script>
    head>
    <body>
      <span>this is bodyspan>
    body>
html>

hello.js

define(function() {
    function sayhello() {
    alert('hello world!');
    }
    sayhello();
});

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

  1. 防止js加载阻塞页面渲染
  2. 不再使用script标签在HTML中引入JS文件,以及不用通过script标签顺序去管理依赖关系

你可能感兴趣的:(javascript,html,模块化,框架,其他)