美文网首页requriejs
Require.js--模块化

Require.js--模块化

作者: 杨刀刀的刀 | 来源:发表于2016-07-13 22:44 被阅读77次

首先简介



一般html页面加载不同的js文件(模块)会使用<script>标签来引入

而多个模块之间可能存在先后依赖关系,如:

<script src="./js/jquery.js"></script>

<script src="./js/echarts.min.js"></script>

<script src="./js/artTemplate.js"></script>

显然,浏览器加载的时候,会停止渲染,整个页面失去响应时间不确定,而且要严格按照依赖性加载,依赖性强的位置靠后

require.js是JS模块原型和理论概念引用的库文件。它的作用就是为了解决依赖性:

1.实现js文件(模块)的异步加载,避免网页失去响应

2.管理模块之间的依赖性,便于代码的编写&维护

project/html页面上引入require.js(下载好放在project/js目录下)

<script src="./js/require.js"></script>

接下来可以加载自己的主模块(./js/main.js)

如果主模块main.js不依赖别的模块,直接写自己的js脚本

如果依赖其他模块就要按照AMD规范来写主模块的require函数

//定义被加载的模块的加载路径


require.config(

    paths:{

           /*BaseUrl:"project/"*/

          "jquery":"./js/jquery.min",  //路径可为相对/绝对路径/网址

          "echarts":"./js/echart"  //require.js加载的就是.js文件 所以.js可省

    }

);

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!

那么这个时候require.js加载的模块默认路径(当前路径)是与引入require.js的html页面的统计目录(BaseUrl:"project/")而需要异步加载的模块在project/js目录下,需要修改当前目录路径(BaseUrl:"./js")


//加载模块

加载模块require(["a","b"],function(a,b){ });

第一个参数:数组(所依赖的模块们)

第二个参数:回调函数(只有在指定依赖的模块加载完成后才会调用此方法)


require(["jquery","echarts"],function(jquery,echarts){

//函数体

});


相关文章

  • Require.js--模块化

    首先简介 一般html页面加载不同的js文件(模块)会使用 标签来引入 而多个模块之间可能存在先后依赖关系,如: ...

  • ES6学习笔记 II

    模块化 注意:模块化需要放到服务器环境使用模块化: 定义模块化如下 export export const a =...

  • 前端开发——模块化(css模块化开发)

    掌握模块化开发的思想是我们进行模块化开发的基础。他有以下几部分组成: 模块化开发的优势 css模块化 css模块化...

  • Node.js模块化学习

    模块化的基本概念Node.js 中模块化npm与包模块的加载机制 模块化的基本概念 什么是模块化 模块化是指解决一...

  • webpack基础笔记

    webpack基础 1.前端工程化 实际的前端开发: 模块化:(js的模块化,css的模块化,资源的模块化) 组件...

  • 模块化开发

    js模块化开发vue模块化开发

  • Vue前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • 前端工程化

    1.模块化的分类 A.浏览器端的模块化 B.服务器端的模块化 C.ES6模块化 小结:推荐使用ES6模块化,因为A...

  • vue5

    es6新内容 class 解构赋值 扩展对象 模块化 什么是模块化 模块的作用 怎么实现模块化 模块化的标准 Co...

  • Vue基础教程之-组件核心概念(四)

    一、模块化 1.1 为什么需要模块化 没有模块化的世界:全局变量污染、难以管理的依赖。常见的模块化标准:Commo...

网友评论

    本文标题:Require.js--模块化

    本文链接:https://www.haomeiwen.com/subject/vohejttx.html