Javascript Bundler
Browserify, Webpack, Rollup, Fuse-box, Parcel
Pourquoi ?
Au début tout était simple
$(document).ready(function(){
$('a[href^=#]').click(function() {
cible=$(this).attr('href');
scrollTo(cible);
return false;
});
});
function scrollTo(cible){
if($(cible).length>=1){
hauteur=$(cible).offset().top;
}
else{
hauteur=$("a[name="+cible.substr(1,cible.length-1)+"]").offset().top;
}
hauteur -= (windowH()-$(cible).height())/2;
$('html,body').animate({scrollTop: hauteur}, 1000,'easeOutQuint');
return false;
}
function windowH(){
if (window.innerHeight) return window.innerHeight ;
else{return $(window).height();}
}
Diviser pour mieux régner
// app.js
$(document).ready(function(){
$('a[href^=#]').click(function() {
cible=$(this).attr('href');
scrollTo(cible);
return false;
});
});
// functions.js
function scrollTo(cible){
if($(cible).length>=1){
hauteur=$(cible).offset().top;
}
else{
hauteur=$("a[name="+cible.substr(1,cible.length-1)+"]").offset().top;
}
hauteur -= (windowH()-$(cible).height())/2;
$('html,body').animate({scrollTop: hauteur}, 1000,'easeOutQuint');
return false;
}
function windowH(){
if (window.innerHeight) return window.innerHeight ;
else{return $(window).height();}
}
// functions.js
function scrollTo(cible){
if($(cible).length>=1){
hauteur=$(cible).offset().top;
}
else{
hauteur=$("a[name="+cible.substr(1,cible.length-1)+"]").offset().top;
}
hauteur -= (windowH()-$(cible).height())/2;
$('html,body').animate({scrollTop: hauteur}, 1000,'easeOutQuint');
return false;
}
function windowH(){
if (window.innerHeight) return window.innerHeight ;
else{return $(window).height();}
}
NodeJS est arrivé
// app.js
var http = require('http');
var dt = require('./date');
http.createServer(function (req, res) {
res.writeHead(200, {'Content-Type': 'text/html'});
res.write("The date and time are currently: " + dt.myDateTime());
res.end();
}).listen(8080);
// date.js
exports.myDateTime = function () {
return Date();
};
Pourquoi ne pas faire pareil
// app.js
var scrollTo = require('./functions/scrollto');
var $ = require('jquery');
$(document).ready(function(){
$('a[href^=#]').click(function() {
cible=$(this).attr('href');
scrollTo(cible);
return false;
});
});
Mais pour le front ?
// scrollto.js
module.exports = function (cible){
if($(cible).length>=1){
hauteur=$(cible).offset().top;
}
else{
hauteur=$("a[name="+cible.substr(1,cible.length-1)+"]").offset().top;
}
hauteur -= (windowH()-$(cible).height())/2;
$('html,body').animate({scrollTop: hauteur}, 1000,'easeOutQuint');
return false;
}
function windowH(){
if (window.innerHeight) return window.innerHeight ;
else{return $(window).height();}
}
ECMAScript 2015
// app.js
import scrollTo from './functions/scrollto'
import $ from 'jquery'
$(document).ready(function(){
$('a[href^=#]').click(function() {
let cible = $(this).attr('href');
scrollTo(cible);
return false;
});
});
Standardise l'utilisation des modules
// scrollto.js
export default function (cible){
// ...
}
// app.js
import { scrollTo } from './functions/scrollto'
import $ from 'jquery'
$(document).ready(function(){
$('a[href^=#]').click(function() {
let cible = $(this).attr('href');
scrollTo(cible);
return false;
});
});
// scrollto.js
export function scrollTo (cible){
// ...
}
export function windowH () {
if (window.innerHeight) return window.innerHeight ;
else{return $(window).height();}
}
Browserify, Webpack, Rollup, Fuse-box, Parcel
JavaScript Bundlers
By Jonathan Boyer
JavaScript Bundlers
- 1,221