require.js简单来说就是把js代码分装模块化了

模块化 模块就是实现特定功能的一组方法。只要把不同的函数(以及记录状态的变量)简单地放在一起,就算是一个模块。

我拿一个运动框架来解释一下require.js模块化

首先要在html页面中插入require.js插件

<script src="require.js"></script>
之后就是创建js文件来分装js代码
define(function(require,exports,module){
exports.getStyle=function (obj,name) {
if(obj.currentStyle){
return obj.currentStyle[name];
}else{
return getComputedStyle(obj,false)[name];
}
};
});
这个函数是获取对象属性的函数
exports是当前模块的导出对象,用于导出模块公有方法和属性简单说就是构造一个公用的函数
define(function(require,exports,module){
var getStyle=require("getStyle").getStyle;
exports.startMove=function (obj,json,complete){
clearInterval(obj.timer);
complete = complete||{};
complete.dur = complete.dur||1000;
complete.easing = complete.easing||'ease-out';
var count=parseInt(complete.dur/30);
var start = {};
var dis = {};
for(name in json){
start[name]=parseFloat(getStyle(obj,name));
dis[name] = json[name]-start[name];
}
var sum=0;
obj.timer=setInterval(function(){
sum++;
for(name in json){
var a=sum/count;
switch(complete.easing){
case 'linear':
var cur = start[name]+a * dis[name];
break;
case 'ease-in':
var cur = start[name]+Math.pow(a,3) * dis[name];
break;
case 'ease-out':
var a=1-sum/count;
var cur = start[name]+(1-Math.pow(a,3))* dis[name];
break;
}
if(name=='opacity'){
obj.style[name]=cur;
obj.style.filter='alpha('+cur*100+')';
}else{
obj.style[name] = cur + 'px';
}
}
if(sum==count){
clearInterval(obj.timer);
complete.fn && complete.fn();
}
},30)
}
})
这个是运动框架的核心代码
var getStyle=require("getStyle").getStyle;
require函数用于在当前模块中加载和使用别的模块,传入一个模块名,返回一个模块导出对象。
define(function(require,exports,module){
var move=require("startMove").startMove;
exports.slider=function () {
var oUl=document.getElementById("pics");
var aBtn=document.getElementsByTagName("span");
var aLi=oUl.children;
oUl.style.width=aLi.length*aLi[0].offsetWidth+"px";
for(var i=0;i<aBtn.length;i++){
aBtn[i].index=i;
aBtn[i].onclick=function(){
for(var j=0;j<aBtn.length;j++){
aBtn[j].className="";
}
aBtn[this.index].className="on";
move(oUl,{left:-this.index*aLi[0].offsetWidth},{easing:"ease-out"});
}
}
}
});
这个是调用运动框架里的函数传入实参来实现效果
var move=require("startMove").startMove;
这个是将之前写过的js文件传入进来,就是一个模块,调用这个模块
require(['tab'],function(mod){
mod.slider('play');
})
调用之前写的那个js模块然后通过在<script>添加data-main="init"来将写的模块传入进来就能实现效果
<script src="require.js" data-main="init"></script>
说白了require.js的好处就是js文件有依赖性有的时候顺序js文件传入顺序不对的话就会报错他有依赖性require.js将这个问题给解决了让js文件即使传入顺序不对也可以执行

require.js模块化的更多相关文章

  1. 初步理解require.js模块化编程

    初步理解require.js模块化编程 一.Javascript模块化编程 目前,通行的Javascript模块规范共有两种:CommonJS和AMD. 1.commonjs 2009年,美国程序员R ...

  2. require.js模块化写法

    模块化 模块就是实现特定功能的一组方法.只要把不同的函数(以及记录状态的变量)简单地放在一起,就算是一个模块. 下述两种写法等价 exports 对象是当前模块的导出对象,用于导出模块公有方法和属性. ...

  3. require.js 模块化

    什么是模块化? 将若干功能进行封装,以备将来被重复使用. 为什么要前端模块化? 将公共功能进行封装实现复用 灵活解决依赖 解决全局变量污染 如何实现前端模块化? <!DOCTYPE html&g ...

  4. require.js 模块化简单理解

    组件化 基于UI 样式布局 没有过多 js 代码操作的 比如:一个导航栏 一个表单 一个搜索框 一个侧边栏 一个html 等等.... 模块化 基于功能模块 一个可以替换的js部分称之为模块(modu ...

  5. require.js模块化管理和加载js(按需加载)简单实例教学

    一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载.下面的网页代 ...

  6. require.js模块化开发

    模块化开发的原因: 1.引入的js过多然后在加载的过程中容易出现假死的状态,导致页面会发生白屏 2.变量名的问题 在多人协作开发的时候容易出现变量名的冲突 面向对象 3.引入优先级的问题 模块化开发分 ...

  7. javascript模块化编程库require.js的用法

    随着javascript的兴起,越来越多的公司开始将JS模块化,以增加开发的效率和减少重复编写代码的.更是为了能更加容易的维护日后的代码,因为现在的随着人们对交互效果的越来越强烈的需求,我们的JS代码 ...

  8. Support for AMD usage of jwplayer (require js)

    使用require js 模块化代码时,其中播放器用的是jwplayer7.x 然后载入jwplayer.js后总是报license无效(license已经加入),最后在jwplayer官网论坛里找到 ...

  9. Uncaught Error: Script error for "popper.js", needed by: bootstrap - require.js

    Uncaught Error: Script error for "popper.js", needed by: bootstrap https://requirejs.org/d ...

随机推荐

  1. mysql脚本转h2

    注意事项:转的时候需要 脚本中不能包含utf8mb4格式

  2. if判断,switch语句

    if ; else if; else; 判断操作: 格式示例: public class scanner { public static void main(String[] args){ int a ...

  3. Metrics-server插件安装配置

    1.创建 metrics-server 使用的证书 vim metrics-server-csr.json { "CN": "aggregator", &quo ...

  4. .net core 2.0 HTTPS request fails using HttpClient 安全错误

    最近.net core 项目中遇到一个问题,通过Httpclient 访问https的接口报错,错误如下: WinHttpException: A security error occurred Sy ...

  5. Android:得到WebView当前页的html源码

    WebView没有提供直接的API,需要用JavaScript变通处理一下.本文试图总结一个最简单.优雅的代码. 有两步: 1.先创建一个JavaScript接口类: class MyJavaScri ...

  6. whereis命令详解

    1.简介: whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b).man说明文件(参数-m)和源代码文件(参数-s).如果省略参数,则返回所有信息. 和find相比,whereis ...

  7. https://github.com/gaoyangxiaozhu/DockerVI

    [更新]分享一个开源项目DockerVI,一个基于NodeJS实现的Docker Swarm可视化解决方案

  8. SpringMVC对ServletAPI的支持和JSON格式的转换

    package com.hongcong.controller; import java.io.UnsupportedEncodingException; import java.net.URLDec ...

  9. java中null是什么,以及使用中要注意的事项

    1.null既不是对象也不是一种类型,它仅是一种特殊的值,你可以将其赋予任何引用类型,你也可以将null转化成任何类型,例如: Integer i=null; Float f=null; String ...

  10. 解决python logging重复写日志问题

    import logging from homework.exam_homework_0413.common import contants from homework.exam_homework_0 ...