seajs的使用
写在前面
seajs是什么?
- Seajs是一个js文件加载器。
- 遵循 CMD 规范模块化开发,依赖的自动加载、配置的简洁清晰。
- 用于Web开发的模块加载工具,提供简单、极致的模块化体验
一:使用
文件目录:

demo_1.html
<!DOCTYPE html>
<html>
<head>
<title></title>
<script src="seajs/sea.js"></script>
<script src="seajs-config.js"></script>
</head>
<body>
<script>
//seajs.use(['./model.js','./model_2.js']) //没有使用别名的写法
seajs.use(['m','m_2']) //使用base路径的写法
</script>
</body>
</html>
**注解:
seajs.use:用来在页面中加载一个或多个模块。
seajs-config.js文件
seajs.config({
//两种写法,一个是paths,一个是base
/*paths:{
'baseUrl':'.'
},
alias:{
'm':'baseUrl/model.js',
'm_2':'baseUrl/model_2.js'
}*/
base:"./",
alias:{
'm':'model.js',
'm_2':'model_2.js'
}
})
**注解:
base:是sea.js的基础路径,也就是sea.js的路径。
paths:当目录比较深,或需要跨目录调用模块时,可以使用paths来简化书写。
如:
seajs.config({
paths: {
'gallery': 'https://a.alipayobjects.com/gallery',
'app': 'path/to/app',
...
}
});
//模块中
define(function(require, exports, module) {
var underscore = require('gallery/underscore');
// 加载的是 https://a.alipayobjects.com/gallery/underscore.js
var biz = require('app/biz');
// 加载的是 path/to/app/biz.js
});
paths 配置可以结合 alias 配置一起使用,让模块引用非常方便。
在使用中路径问题出错了。
路径问题:https://github.com/seajs/seajs/issues/258 seajs都有相关解释。
alias:别名配置,用变量表示文件,解决路径层级过深和实现路径映射
model.js文件:
define(function(){
alert("AAA")
})
**注解:
define:用来定义一个模块。
model_2.js文件:
define(function(){
alert("BBB")
})
结果:根据两个文件在seajs中的加载顺序,分别弹出AAA与BBB。
二:使用
页面:
<!DOCTYPE html>
<html>
<head>
<title></title>
<script src="seajs/sea.js"></script>
<script src="seajs-config.js"></script>
</head>
<body>
<div></div>
</body>
<script>
seajs.use(['jquery','m_3'],function($,m_3){
//这里是callback
//$对应jquery,在回调中使用的别名
//调用接口变量
alert(m_3.msg);
})
</script>
</html>
seajs-config.js文件
seajs.config({
/*paths:{
'baseUrl':'.'
},
alias:{
'm':'baseUrl/model.js',
'm_2':'baseUrl/model_2.js'
}*/
base:"./",
alias:{
'jquery':'jquery.js',
'm':'model.js',
'm_2':'model_2.js',
'm_3':'model_3.js'
}
})
model_3.js文件:
define(function(require, exports, module){
var $=require('jquery');
$("div").text("模块中调用jquery操作dom");
exports.msg="对外接口,变量a";
})
结果:
**注解:
require:用来获取指定模块的接口。
exports:用来在模块内部对为提供接口。
三:jQuery在seajs中的使用
需要使用seajs来定义一下,包装成一个模块。
define(function(){
//jquery源代码
return $.noConflict();
});
四:有时候,我们添加前端框架的时候,需要引入css文件时。
以bootstrap为例:两个文件,bootstrap.js与bootstrap.css文件。
bootstrap.js文件做一下的修改即可。
define(function(require, exports, module){
require('bootstrap.css');
//里面是bootstrap.js的源码
})
seajs的使用的更多相关文章
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- 初学seaJs模块化开发,利用grunt打包,减少http请求
原文地址:初学seaJs模块化开发,利用grunt打包,减少http请求 未压缩合并的演示地址:demo2 学习seaJs的模块化开发,适合对seajs基础有所了解的同学看,目录结构 js — —di ...
- JS模块化开发:使用SeaJs高效构建页面
一.扯淡部分 很久很久以前,也就是刚开始接触前端的那会儿,脑袋里压根没有什么架构.重构.性能这些概念,天真地以为前端===好看的页面,甚至把js都划分到除了用来写一些美美的特效别无它用的阴暗角落里,就 ...
- 用spm2构建seajs项目的过程
前言 Javascript模块化规范有CommonJs规范,和主要适用于浏览器环境的AMD规范,以及国内的CMD规范,它是SeaJs遵循的模块化规范.因为以前项目中用SeaJs做过前端的模块管理工具, ...
- jquery插件封装成seajs模块
jquery直接在html中引入. jquery插件修改为: define(function (require, exports, moudles) { return function (jquery ...
- 快速上手seajs——简单易用Seajs
快速上手seajs——简单易用Seajs 原文 http://www.cnblogs.com/xjchenhao/p/4021775.html 主题 SeaJS 简易手册 http://yslo ...
- seajs学习一天后的总结归纳
公司项目最近需要将js文件迁移到seajs来进行模块化管理,由于我以前主要接触模块化开发是接触的AMD规范的requireJS,没有接触过CMD规范,而且在实际项目中还没有用过类似技术.于是,我非常兴 ...
- RequireJS与SeaJS模块化加载示例
web应用越变的庞大,模块化越显得重要,尤其Nodejs的流行,Javascript不限用于浏览器,还用于后台或其他场景时,没有Class,没有 Package的Javascript语言变得难以管理, ...
- 新手 gulp+ seajs 小demo
首先,不说废话,它的介绍和作者就不在多说了,网上一百度一大堆: 我在这里只是来写写我这2天抽空对seajs的了解并爬过的坑,和实现的一个小demo(纯属为了实现,高手请绕道); 一.环境工具及安装 1 ...
随机推荐
- 我的MYSQL学习心得(一) 简单语法
我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据类型 我的MYSQL学习心得(五) 运 ...
- Hive on Spark安装配置详解(都是坑啊)
个人主页:http://www.linbingdong.com 简书地址:http://www.jianshu.com/p/a7f75b868568 简介 本文主要记录如何安装配置Hive on Sp ...
- Hawk 5. 数据库系统
Hawk在设计之初,就是以弱schema风格定义的.没有严格的列名和列属性.用C#这样的静态强类型语言编写Hawk,其实并不方便.但弱schema让Hawk变得更灵活更强大. 因此,Hawk虽然之前支 ...
- 操作系统篇-分段机制与GDT|LDT
|| 版权声明:本文为博主原创文章,未经博主允许不得转载. 一.前言 在<操作系统篇-浅谈实模式与保护模式>中提到了两种模式,我们说在操作系统中,其实大部分时间是待在保护模式中的. ...
- OpenCV人脸识别LBPH算法源码分析
1 背景及理论基础 人脸识别是指将一个需要识别的人脸和人脸库中的某个人脸对应起来(类似于指纹识别),目的是完成识别功能,该术语需要和人脸检测进行区分,人脸检测是在一张图片中把人脸定位出来,完成的是搜寻 ...
- 简记某WebGIS项目的优化之路
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1. 背景 该项目为研究生时的老师牵头,个人已毕业数年,应老师要求协助其 ...
- 彻底搞懂Javascript的“==”
本文转载自:@manxisuo的<通过一张简单的图,让你彻底地.永久地搞懂JS的==运算>. 大家知道,==是JavaScript中比较复杂的一个运算符.它的运算规则奇怪,容让人犯错,从而 ...
- SharePoint 2013: A feature with ID has already been installed in this farm
使用Visual Studio 2013创建一个可视web 部件,当右击项目选择"部署"时报错: "Error occurred in deployment step ' ...
- Android Studio切换为eclipse的快捷键之后还是有区别的部分快捷键
Android Studio Eclipse 把代码提示换成了Class Name Completion, 快捷键是Ctrl+Alt+Space(空格键). 代码提示快捷键Alt+/, ...
- 张高兴的 UWP 开发笔记:汉堡菜单进阶
不同于Windows 8应用,Windows 10引入了"汉堡菜单"这一导航模式.说具体点,就拿官方的天气应用来说,左上角三条横杠的图标外加一个SplitView控件组成的这一导航 ...