require.js 笔记
1.前言
随着网站功能逐渐丰富,网页中的js也变得越来越复杂和臃肿,原有通过script标签来导入一个个的js文件这种方式已经不能满足现在互联网开发模式,我们需要团队协作、模块复用、单元测试等等一系列复杂的需求。
通过script标签来导入众多的js文件有几个缺点:
- 文件的引入路径难以书写,一大串路径字符串难以记忆,也不直观
- 无法清晰的表明各种库之间的依赖关系,一旦引入顺序出错就不能正常执行
- 所有的js都处在同一个作用域下,容易造成全局变量污染
而require.js做到了这一点,它是一个非常小巧的JavaScript模块载入框架,是AMD规范最好的实现者之一。
相关代码笔记:简易demo
2.基本使用
- 引入require.js,并指定主模块的路径
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!-- 引入require.js 并指定主模块的路径 -->
<script src="/assets/libs/require/require.js" data-main="/assets/js/require-backend.js"></script>
<title>主页</title>
</head>
<body>
</body>
</html>
- 主模块:相关路径配置,依赖配置,引入公共模块,引入页面js
//定义相关配置
require.config({
baseUrl : "/assets", //基础路径 只针对 paths 下的字段生效
//模块路径配置
paths:{
'vue':['libs/vue/vue.min', 'https://cdn.bootcdn.net/ajax/libs/vue/2.6.12/vue.min'], //1.数组中可设多个路径 2.无需.js后缀
'ELEMENT': 'libs/element-ui/index.min',
},
map: {
'*': {
//引入require-css,使其支持加载css
'css': '/assets/libs/require-css/css.min.js'
}
},
shim: { //声明模块依赖
'ELEMENT': ['css!/assets/libs/element-ui/index.min.css'],//如果引入了ELEMENT模块,则自动引入这个css文件
}
})
//vue和element-ui每个页面都会用到,所以作为公共模块引入
//每个页面都有其对应的js模块,需要为其配置相应的规则,使其根据页面路径自动引入
//引入页面公共模块和页面js模块
require(['vue','ELEMENT'],function(Vue,ELEMENT){
//安装element-ui
Vue.use(ELEMENT)
//将Vue渲染至全局
window.Vue = Vue
//设定js基本路径
var baseJsPath = "/assets/js"
//获取当前页面路径
var page_path = window.location.pathname
//判断路径是否以 .html 结束
if(page_path.lastIndexOf('.html') > -1 && (page_path.length - 5) == page_path.lastIndexOf('.html')){
//页面路径完整(需去除.html后缀 再拼接)
var jsPath = baseJsPath + page_path.slice(0,-5) + '.js'
}else if(page_path.lastIndexOf('/') > -1 && (page_path.length - 1) == page_path.lastIndexOf('/')){//判断是否已 / 结尾
//页面路径不完整(需要拼接 index.js)
var jsPath = baseJsPath + page_path + 'index.js'
}else{
//页面路径不完整(说明无需去除.html后缀 直接拼接)
var jsPath = baseJsPath + page_path + '.js'
}
//引入页面的js文件
require([jsPath],function(){
})
})
- 页面js
define([],function(utils){
new Vue({
el:"#app",
data(){
return {
}
}
})
})
3.封装自定义模块
模块定义使用define()方法,他有3个参数:
| 参数 | 类型 | 说明 |
|---|---|---|
| 参数一 | String | 可选,当前模块名称,一旦设定,在配置模块路径(paths)是就必须使用该名称 |
| 参数二 | Array | 可选,依赖的模块 |
| 参数三 | Function | 模块的定义,需要return一个数据作为当前模块的暴漏值 |
define('name_utils',[],function () {
return {}
})
某些库就是使用这种方式定义的,所以引入是名称必须固定,例如jquery和elementui


像上面的依赖,elementui的源码已经指明依赖vue,一旦页面引入了elementui,即使没有引入vue,则require.js会自动引入vue,但是在回调中无法拿到Vue这个类,导致页面无法使用vue渲染,也无法安装elementui,所以还是得手动引入vue,require.js会自动忽略重复的请求
4.加载css
- 加载css需要用到require-css插件,在主模块中引入这个插件,确保后面所有的模块都可正常加载css
require.config({
map: { //map告诉RequireJS在任何模块之前,都先载入这个css模块
'*': {
css: 'https://cdn.bootcdn.net/ajax/libs/require-css/0.1.9/css.js'
}
}
})
- 例1:element-ui依赖其配套的css,我们在shim字段中为element-ui声明他所需要的依赖。
require.config({
map: { //map告诉RequireJS在任何模块之前,都先载入这个css模块
'*': {
css: 'https://cdn.bootcdn.net/ajax/libs/require-css/0.1.9/css.js'
}
},
shim: { //声明模块依赖
'ELEMENT':{
"deps":['css!https://cdn.bootcdn.net/ajax/libs/element-ui/2.15.2/theme-chalk/index.css'], //声明 'ELEMENT' 的依赖
}
}
})
- 例2:引入页面的css文件,在引入时添加前缀 "css!" 后面跟css文件路径即可

当然,页面的js和css可以集中主模块中进行引入
//引入页面js映射模块
require([],function(){
//加载页面对应的js和css (部分代码省略)
require([jsPath, 'css!'+cssPath],function(){
})
})
5.加载非规范的模块
require.js的模块使用define()方法进行定义,在回调中return一个数据,其他模块引入他的时候,就能够接收到这个模块,参考上面的封装自定义模块

但是如果在define()的参数回调中,没有return任何数据,或者编写js模块时,未使用模块化的写法,,则无法接收,显示undefined

上面的js定义了不止一个数据,我们可以指定其中的一个作为模块进行引入
require.config({
//模块路径配置
paths:{
'utils':"js/utils"
},
shim: { //声明模块依赖
'utils':{
exports:"utils",//本例中可以sayHello和utils二选一
}
}
})

require.js 笔记的更多相关文章
- require.js笔记
笔记参考来源:阮一峰 http://www.ruanyifeng.com/blog/2012/10/javascript_module.html 1. 浏览器端的模块只能采用“异步加载”方式 = ...
- require.js 入门笔记
网站越来越庞大,JS也是越写越多. 当所有的JS 都集中在 HTML的 head 部分时,网页加载变得很慢,很多的 JS代码也并不是全都适用在当前的页面,造成了代码的冗余度非常高. 而且长长的JS代码 ...
- 【转】require.js学习笔记(二)
require.js遵循AMD规范,通过define定义模块,require异步加载模块,一个js文件即一个模块. 一.模块加载require1.加载符合AMD规范模块 HTML: <scrip ...
- require.js学习笔记(内容属于转载总结)
<script data-main="src/app" src="src/lib/require.js"></script> backb ...
- require.js学习笔记
使用require.js的好处? 1 有效的防止命名冲突(可以将变量封装在模块内,通过暴露出的接口解决命名冲突) 2 解决不同JS文件中的依赖 3 可以让我们的代码以模块化的方式组织 官方网站http ...
- 【转】require.js学习笔记(一)
一.立即执行函数 立即执行函数可以有效避免临时变量污染全局空间.可以在页面初始化时,在立即执行函数内实现一次执行变量的定义及使用. for (var i = 0; i < elems.lengt ...
- 【笔记】关于require.js 的用法
最近忙于学校的一个新网站建设,对于以前的前端程序编写方式的不正规特意上网学习了require.js 的用法,使此次的工程更加有条理同时符合当前前端的开发模式——前端模块化. 网上有不少很好的学习文章这 ...
- require.js源码分析
写的寥寥草草,博客园的布局怎么弄还没有研究,再保存一份草稿,日后在完善,深度研究 require.js 加载顺序 1:加载html主页,require.js文件 2:脚本执行到html中的script ...
- javascript模块化编程库require.js的用法
随着javascript的兴起,越来越多的公司开始将JS模块化,以增加开发的效率和减少重复编写代码的.更是为了能更加容易的维护日后的代码,因为现在的随着人们对交互效果的越来越强烈的需求,我们的JS代码 ...
- Javascript模块化编程(三):require.js的用法
Javascript模块化编程(三):require.js的用法 原文地址:http://www.ruanyifeng.com/blog/2012/11/require_js.html 作者: 阮一峰 ...
随机推荐
- Vue3——axios 安装和封装
axios 安装和封装 安装 npm install axios 最后通过 axios 测试接口!!! axios 二次封装 在开发项目的时候避免不了与后端进行交互,因此我们需要使用 axios 插件 ...
- Windows Terminal3.1
其实就是为了把之前写的东西集成起来所以搞了一个终端. 下载 集成功能 Wordle ABCG RandTool cmd 便捷功能 FastFile (快速打开目标文件夹) show 文件说明 Term ...
- MySQL下载安装教程
下载 https://www.mysql.com/downloads/
- KubeSphere 核心架构浅析
作者简介:万宏明,KubeSphere 核心贡献者,专注于云原生安全领域. KubeSphere 是在 Kubernetes 之上构建的面向云原生应用的容器混合云管理系统.支持多云与多集群管理,提供全 ...
- 基于 KubeSphere 的 AI 平台开发实践
概述 本文基于 "KubeSphere & Friends 2021 Meetup 北京站" 分享主要内容整理而来,详细内容建议观看视频,本文有一定删减. 作者:胡涛(Da ...
- [Go] 如何妥善处理 TCP 代理中连接的关闭
如何妥善处理 TCP 代理中连接的关闭 相比较于直接关闭 TCP 连接,只关闭 TCP 连接读写使用单工连接的场景较少,但通用的 TCP 代理也需要考虑这部分场景. 背景 今天在看老代码的时候,发现一 ...
- C# 13(.Net 9) 中的新特性 - 半自动属性
C# 13 即 .Net 9 按照计划会在2024年11月发布,目前一些新特性已经定型,今天让我们来预览其中的一个新特性: 作者注:该特性虽然随着 C# 13 发布,但是仍然是处于 preview 状 ...
- 『玩转Streamlit』--页面布局
一个优秀的数据应用不仅仅是功能的强大,更在于其用户体验的打造. 而良好的页面布局,作为用户体验的重要组成部分,不仅能够提升信息的可读性,还能引导用户高效地完成操作. 反之,混乱的布局会让人感到困惑和挫 ...
- 使用-solidity-开发第一个-以太坊智能合约
目录 目录 使用 solidity 开发第一个 以太坊智能合约 前言 项目源代码 最终效果 环境搭建 智能合约内容 Truffle 创建项目 Truffle 编码 Truffle 打包 Truffle ...
- 【2024.09.27】NOIP2024 赛前集训-刷题训练(3)
[2024.09.27]NOIP2024 赛前集训-刷题训练(3) NOIP2018 提高组 铺设道路 算法一:模拟正常人铺路的过程,每次找区间的最小值,最小值就是本次填的高度,由于出现了若干个0位置 ...