1.base说明:
base是字符串类型,表示基础或叫做根路径(最好绝对地址)
备注:
(1)base如果不写的话是根据你引用sea.js的地址目录
(2)base如果写了’.’或者 ‘/’或者’ ’这些,会默认从服务根目录开始
(3)base如果写了’js/’之类的相对路径,会默认根据你引用sea.js的地址目录
例如:
seajs.config({
base: 'http://example.com/path/to/base/'
})
2.alias说明
例如:
seajs.config({
base: 'http://example.com/path/to/base/',
// 别名配置
alias: {
'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',
'jquery': 'jquery/jquery/1.10.1/jquery'
}
})
引入的时候:加载模块(seajs.use("es5-safe")) 引入模块 :(require("jquery"))
3.paths说明:
当目录比较深,或需要跨目录调用模块时,可以使用paths来简化书写。
例如:
seajs.config({
base:'http://example.com/path/to/base/',
//表示路径配置
paths:{
'cwd':'static/common/js'
},
alias: {
'es5-safe': 'gallery/es5-safe/0.9.3/es5-safe',
'jquery': 'jquery/jquery/1.10.1/jquery',
'jquery':'cwd/common/jquery-1.11.3'//alias中使用 static/common/js/common/jquery-1.11.3
}
})
seajs.use('cwd/project/AA')//static/common/js/project/AA
var index = require(cwd/index)// static/common/js/index.js
4.map说明:
map是Array类型,表示配置可对模块路径进行映射修改,可用于路径转换、在线调试等。
例如:
seajs.config({
map: [
//[ '.js' , '-debug.js' ]
['.js' , '.js?_t='+(new Date).getTime()]
]
})
define(function(require, exports, module) {
var a = require('./a')
//=>加载的是 path/to/a-debug.js
})
5.preload说明:(备注该属性在V2.3版本时候去除了)
preload是Array或String类型,表示预加载项,可以在普通模块加载前,提前加载并初始化好指定模块。
备注:preload中的空字符串会被忽略掉。使用时需要等到 use 才加载
例如:
seajs.config({
preload: ["jquery"]
})
6.debugBoolean 调试使用
值为 true 时,加载器不会删除动态插入的 script 标签。插件也可以根据 debug 配置,来决策 log 等信息的输出。
seajs.config({
debug:true
})
7.vars变量配置
有些场景下,模块路径在运行时才能确定,这时可以使用vars变量来配置。
seajs.config({
vars: {
'locale': 'zh-cn'
}
})
define(function(require, exports, module) {
var lang = require('./i18n/{locale}.js')
//=>加载的是 path/to/i18n/zh-cn.js
})
vars配置的是模块标识中的变量值,在模块标识中用{key}来表示变量。
二、 define
1.所有模块都通过 define 来定义
define(function(require, exports, module) {
(1). // 通过require.async引入依赖(引入模块)
require.async是异步加载的在引入后,的回调函数中才能使用,函数返回值就是require对象
require.async("jquery",fun) 异步加载模块 jquery(别名) fun回调函数(可选参数)
require.async(['lib/common/common.js','lib/common/index.js'],function(){
Echo.init({
offset: 150, //离可视区域多少像素的图片可以被加载
throttle: 10 //图片延迟多少毫秒加载
})
}) //调用多个模块 fun回调函数可选()
(2).require引入依赖(引入模块)
Require引入就可以使用
var Spinning = require('lib/common/common.js') 基础地址/lib/common/common.js
Spinning.tostring() 调用Spinning里面的tostring方法
require直接引入整个文件
require.async(["swiper"], function() {
require('module/Mycenter/mycenter')
})
2.对外暴露接口
// 通过exports对外提供接口
exports.tonumber = function(){ var a = 0}
// 或者通过module.exports提供整个接口 (推荐使用)
module.exports.tonumber = function(){ var a = 0}
})
三 、use()
seajs.use 用来在页面中加载模块。通过 use 方法,可以在页面中加载任意模块。use 的模块路径相对于当前页面
语法:seajs.use(id, callback?)
// 加载模块 main,并在加载完成时,执行指定回调
seajs.use(‘./main’)加载模块
seajs.use(‘./main’, function(main) {
main.init()
})
use 方法还可以一次加载多个模块:
// 并发加载模块 a 和模块 b,并在都加载完成时,执行指定回调
seajs.use(['./a', './b'], function(a, b) { 加载多个模块 fun回调函数(可选参数)
a.init()
b.init()
})
四、注意
引入 sea.js 时,可以把 sea.js 与其他文件打包在一起,可提前合并好,或利用 combo 服务动态合并。无论哪一种方式,为了让 sea.js内部能快速获取到自身路径,推荐手动加上 id 属性:
seajs.config
alias
别名配置,配置之后可在模块中使用require调用 require('jquery')
paths
设置路径,方便跨目录调用。通过灵活的设置path可以在不影响base的情况下指定到某个目录。
vars
变量配置。有些场景下,模块路径在运行时才能确定,这时可以使用 vars变量来配置。
vars 配置的是模块标识中的变量值,在模块标识中用 {key}来表示变量。
map
该配置可对模块路径进行映射修改,可用于路径转换、在线调试等。
preload
使用preload配置项,可以在普通模块加载前,提前加载并初始化好指定模块。
注:preload中的空字符串会被忽略掉。
注:preload中的配置,需要等到 use 时才加载。比如:
注:preload 配置不能放在模块文件里面:
debug
值为true时,加载器不会删除动态插入的 script 标签。插件也可以根据debug配置,来决策 log 等信息的输出。
base
Sea.js 在解析顶级标识时,会相对 base 路径来解析。
charset
获取模块文件时,<script>或 <link>标签的charset属性。 默认是utf-8
charset还可以是一个函数:
seajs.use
用来在页面中加载一个或多个模块。seajs.use(id, callback?)
注意:seajs.use 与 DOM ready 事件没有任何关系。如果某些操作要确保在 DOM ready 后执行,需要使用 jquery 等类库来保证。比如
注意:use方法第一个参数一定要有,但是可以是null,也可以是一个变量
seajs.cache
通过 seajs.cache,可以查阅当前模块系统中的所有模块信息。
比如,打开 seajs.org,然后在 WebKit Developer Tools 的 Console 面板中输入 seajs.cache,可以看到:
seajs.reslove
类似require.resolve,会利用模块系统的内部机制对传入的字符串参数进行路径解析。
seajs.data
通过 seajs.data,可以查看 seajs 所有配置以及一些内部变量的值,可用于插件开发。当加载遇到问题时,也可用于调试。
关于自学前端好找工作吗?
自学前端,很多人学不好的,还没学到找工作的阶段,在学习的阶段很多同学就已经放弃了。而且我们发现一个问题,很多自学出来的学生,前端的开发水平是很弱的,知识点掌握不扎实,也缺乏前端思维,没有对这方面的深入理解和思考,缺乏与时俱进的东西,有一种思维被框限的感觉。靠自学即便找到工作,由于水平不高,也很容易造成工资不高,在公司里和专业的出来的有差距,后期晋升也不是太容易。
你必须知道的学好前端的六点建议。
(1)夯实基础。
要成为一名年薪30W的前端工程师,基础一定要掌握牢固,基础知识一问三不知,岂不是要贻笑大方。css,js基础知识一定要掌握得很熟练,你能使用css实现斑马条纹背景,毛玻璃效果吗?能给图片实现滤镜效果,能实现所有自适应布局效果吗?原型,原型链,闭包是实现设计模式的必备知识,你真的弄懂了吗?闭包导致内存泄漏的原因是什么,你弄明白了吗?ajax跨域的解决方案你可以说几种?你还是只告诉我jsonp吗?http协议有了解过吗?如何在http协议中实现不缓存静态资源?
不要说这些问题老掉牙了。可是我要告诉你的是,掌握好这些老掉牙的基础,就是很重要。上层的技术可以变更的很快,基础变动很慢,投入时间学好基础,性价比很高。
(2)深究原理。
Angular,React,Vue框架和脚手架的普及,越来越多的前端工程师浮于表面,调用框架的API完成任务就完事。要成为一名优秀的前端,绝不能成为单纯的"API调用工程师",一定要掌握框架背后的原理性知识。
Virtual DOM diff算法,双向绑定原理等等框架背后的机制都值得我们去学习。框架API可以更新很快,而他们背后的原理都是相似的,学好原理既可以让我们对框架底层了解更深入,又可以使我们迅速掌握不断更新的框架表层。只会用框架永远也成不了大神。
(3)注重细节。
在工作中,做事得过且过的人往往难堪大任,作为前端工程师,亦不例外。"代码能用就行"的认识往往是初级程序员的通病。作为有在技术道路上有理想的工程师,一定要对自己的代码严格要求,精益求精。
比如HTML一定要注意语义化以方便SEO优化,该用<section>,<head>,<foot>的地方不能一股脑儿用<div>完事css中编写样式时不能页面上样式是有了,类名和属性排序写得一塌糊涂,建议大家按照BEM规范编写风格良好的代码;js中变量命名随意是很常见的不规范行为,一个不直观的变量名往往使同事看了脑袋大。
“代码千万行,注释第一行。命名不规范,同事两行泪。“一首流行诗,饱含了多少程序员的血与泪。
(4)登高见远.
前端经历了这么多年的飞速发展,早已成为浩瀚的大海。如果闷着头独自钻研苦学,那无疑是很慢的。
如果我们直接去跟随大神学习,那将会使我们快速成长。github上有很多优秀的前端项目,仔细研读这些项目的代码,在commit记录中查看编程思想和逻辑的进化过程,就是一场与大神直接的面对面交流,是一场绝妙的学习之旅。
现在网络课程也十分丰富,有很多技术大牛的课程让我们直接通过视频生动的讲解快速地学习技术,这何尝不是一种向大神快速学习的方式呢。
(5)良书益友。
虽然现在网络上各种文档、博客文章已经很丰富了,但是对工作经验不足,基础薄弱的同学来说,随手拿起书,时时能学习也是一种很好的方法,查漏补缺,完整地夯实基础。
(6)紧跟潮流。
现在的前端技术体系更新十分迅速,想着要不要尝试用下Vue的事仿佛还在昨天,今天一觉醒来就看到尤雨溪宣布要开发Vue3.0了。
前端体系中这两年SPA已经不是新名词,PWA,SSR,小程序愈发流行,前端微服务化的趋势也应运而生,RN,electron在移动端,桌面端的使用也越来越多,ES10标准的发布也没几个月了。所以最重要的是突破当前岗位需求的设限,对各种技术融会贯通,创造新的技术框架,做技术的领头羊,适应时代发展。技术人成长不能再单打独斗,要学会与人交流,学会将别人的知识为自己所用。
对前端开发感兴趣吗?不知道该如何学习前端知识?点击这里:http://www.bjsxt.com/,海量视频教程随你挑!