文艺小说-?2F,言情小说-?3F,武侠小说-?9F

  long long ago time-1-1:A 使用工具,long long A ago time-1-2:A 使用分类工具,long long ago time-1-3:A 使用一键构建工具 (js组件构建)

  long long ago time-2-1:B 使用工具,long long A ago time-2-2:B 使用兼容工具,long long ago time-2-3:B 使用一键构建工具 (cs样式兼容)

  前端正在由蛮荒步入高阶时代!

读在最前面:

  1、本文讲述Angular,Webpack 模块化、按需加载案例,移步Vue

  2、阅读本文,读者应了解Angular、WebPack,!移步 我乃webpack

  3、此文建立在已有node环境,sass环境,webpack环境下,特此说明

  4、此文适合那些对前端优化(按需加载、请求合并、文件指纹、CDN部署、、首屏CSS内嵌 and so on)、组件化、工程化有一些思考的同学

  5、技术点:angular、webpack、oclazyload、sass、autoprefixer

  6、以下代码只帖出关键代码,下载完整项目,请拉到最底部!

构建Angular,Fire!

1、创建angular入口文件,app.js

描述:

(1)、第三方样式依赖:font-awesome

(2)、第三方js依赖:angular,angular-ui-router,oclazyload

(3)、业务逻辑、公共组件依赖:routing.js,directive.js

'use strict';
require('../../node_modules/font-awesome/css/font-awesome.min.css'); angular.module('app', [
require('angular-ui-router'),
require('oclazyload'),
require('./routing.js'),
require('./directive.js')
])
.config(function($urlRouterProvider, $locationProvider) {
$urlRouterProvider.otherwise("home");
$locationProvider.html5Mode(true);
});

2、创建路由配置文件,routing.js

'use strict';
module.exports = angular.module('app.controllers', [
require('../view/home/_service.js'),
require('../view/main/_service.js')
]).name;

3、创建home路由文件,_service.js

描述:

(1)、使用require.ensure实现异步加载 see more

(2)、使用ocLazyLoad加载业务控制

'use strict';
module.exports = angular.module('app.home', []).config(function($stateProvider) {
$stateProvider.state('home', {
url: '/home',
templateProvider: function($q) {
var deferred = $q.defer();
require.ensure(['./home.html'], function(require) {
var template = require('./home.html');
deferred.resolve(template);
}, 'home-tpl');
return deferred.promise;
},
controller: 'homeCtrl',
controllerAs: 'vm',
resolve: {
'app.home': function($q, $ocLazyLoad) {
var deferred = $q.defer();
require.ensure(['./home.js'], function() {
var mod = require('./home.js');
$ocLazyLoad.load({
name: 'app.home'
});
deferred.resolve(mod.controller);
}, 'home-ctl');
return deferred.promise;
}
}
});
}).name;

4、创建控制器文件,home.js

'use strict';
module.exports = angular.module("app.home").controller("homeCtrl", function() {
this.test = function() {
alert(this.name);
}
}).name;

  

构建WebPack,Fire!

1、创建环境Json

{
"name": "front-solution",
"version": "1.0.0",
"description": "front-solution",
"main": "index.js",
"scripts": {
"build": "set NODE_ENV=build&&webpack -p --progress --colors",
"test": "set NODE_ENV=test&&webpack -p --progress --colors",
"dev": "set NODE_ENV=dev&& webpack-dev-server --hot --progress --colors --host 0.0.0.0 --port 8080"
},
"keywords": [
"front-solution"
],
"author": "lufeng",
"license": "ISC",
"devDependencies": {
"autoprefixer": "^6.6.0",
"clean-webpack-plugin": "^0.1.14",
"css-loader": "^0.26.1",
"extract-text-webpack-plugin": "^1.0.1",
"file-loader": "^0.9.0",
"font-awesome": "^4.7.0",
"html-webpack-plugin": "^2.24.1",
"ng-annotate-webpack-plugin": "^0.1.3",
"node-sass": "^4.1.1",
"postcss-loader": "^1.2.1",
"raw-loader": "^0.5.1",
"sass-loader": "^4.1.1",
"style-loader": "^0.13.1",
"url-loader": "^0.5.7",
"webpack": "^1.14.0",
"webpack-dev-server": "^1.16.2"
},
"dependencies": {
"angular": "^1.6.1",
"angular-ui-router": "^0.3.2",
"oclazyload": "^1.0.9"
}
}

2、创建打包步骤

var webpack = require('webpack'),
HtmlWebpackPlugin = require('html-webpack-plugin'), //模板插件
ExtractTextPlugin = require("extract-text-webpack-plugin"), //Css分割插件
CleanWebpackPlugin = require('clean-webpack-plugin'), // 删除插件
NgAnnotatePlugin = require('ng-annotate-webpack-plugin'), //自动注入注解插件
autoprefixer = require('autoprefixer'),
path = require('path'),
buildPath = path.resolve(__dirname, "build"), //发布目录
__DEV__ = process.env.NODE_ENV === 'dev', //发布环境
publicPath = '', //资源引用统一前缀
devtool = '', //source-map模式 plugins = [
new HtmlWebpackPlugin({
chunks: ['app', 'vendor'],
template: __dirname + '/www/template/index.html',
filename: './index.html'
}),
new HtmlWebpackPlugin({
chunks: ['app', 'vendor'],
template: __dirname + '/www/template/mobile.html',
filename: './mobile.html'
}),
new webpack.optimize.CommonsChunkPlugin('vendor', 'script/vendor.[hash:6].js'),
new ExtractTextPlugin("/css/styles.[hash:6].css"),
new CleanWebpackPlugin('build', {
verbose: true,
dry: false
}),
new NgAnnotatePlugin({
add: true
})
]; if (!__DEV__) {
//压缩
plugins.push(new webpack.optimize.UglifyJsPlugin({
compress: {
warnings: false
}
})); publicPath = process.env.NODE_ENV == 'test' ? 'test.domain.com' : 'www.domain.com';
devtool = 'source-map';
} var config = {
//入口文件配置
entry: {
app: path.resolve(__dirname, 'www/app/app.js'),
vendor: ["angular", 'angular-ui-router', 'oclazyload']
},
//文件导出的配置
output: {
path: buildPath,
filename: "script/[name].[hash:6].js",
publicPath: publicPath,
chunkFilename: "chunks/[name].chunk.[chunkhash].js"
},
//本地服务器配置
devServer: {
historyApiFallback: true,
hot: true,
inline: true,
grogress: true
},
//模块配置
module: {
loaders: [{
test: /\.html$/,
loader: 'raw'
}, {
test: /\.(png|jpg|gif)$/,
loader: 'url?limit=8192,name=/img/[name].[hash:6].[ext]'
}, {
test: /\.(woff|woff2|eot|ttf|svg)(\?.*$|$)/,
loader: 'url-loader?importLoaders=1&limit=1000&name=/fonts/[name].[ext]'
}, {
test: /\.css$/,
loaders: ['style', 'css'],
}, { //外链
test: /\.scss$/,
loader: ExtractTextPlugin.extract("style-loader", "css-loader!sass-loader!postcss-loader")
}
// ,{ //内联
// test: /\.scss$/,
// loaders: ['style', 'css', 'sass','postcss']
// }
]
},
postcss: function() {
return [autoprefixer()];
},
//插件配置
plugins: plugins,
//调试配置
devtool: devtool
} module.exports = config;

备注:

      1、原理说明:webpack采用依赖(require)来进行项目构建,一切皆require,它会根据你在webcofig中配置的js入口文件进行检索,然后构建出你整个资源环境。

   2、配置说明:

    (1)、angular构建中,按需加载主要涉及:require,ocLazyLoad

    (2)、webpack构建中,主要涉及插件包括:html模板、css分隔、自动注解、目录删除、文件压缩、文件指纹

    (3)、webpack构建中,主要涉及loader包括:css、sass、postcss、file、url、style、raw

    3、猛击下载源码

    

by:海豚湾-丰

  

Angular (SPA) WebPack模块化打包、按需加载解决方案完整实现的更多相关文章

  1. webpack中实现按需加载

    webpack中的require.ensure()可以实现按需加载资源包括js,css等,它会给里面require的文件单独打包,不和主文件打包在一起,webpack会自动配置名字,如0.js,1.j ...

  2. 深入浅出的webpack4构建工具---webpack+vue+router 按需加载页面(十五)

    1. 为什么需要按需加载? 对于vue单页应用来讲,我们常见的做法把页面上所有的代码都打包到一个bundle.js文件内,但是随着项目越来越大,文件越来越多的情况下,那么bundle.js文件也会越来 ...

  3. webpack学习笔记--按需加载

    为什么需要按需加载 随着互联网的发展,一个网页需要承载的功能越来越多. 对于采用单页应用作为前端架构的网站来说,会面临着一个网页需要加载的代码量很大的问题,因为许多功能都集中的做到了一个 HTML 里 ...

  4. React Router 4.0 + webpack 实现组件按需加载

    网上关于React Router 4.0的按需加载文章有很多,大致的思路都一样,但是其实具体实现起来却要根据自己的实际情况来定,这里主要介绍一下我的实现方式. 主要方式是通过Route组件的rende ...

  5. webpack require.ensure 按需加载

    使用 vue-cli构建的项目,在 默认情况下 ,会将所有的js代码打包为一个整体比如index.js.当使用存在多个路由代码的时候,index.js可能会超大,影响加载速度. 这个每个路由页面除了i ...

  6. webpack 事件触发 按需加载

    比较易懂, 方法简单 var util_sync = require('./util-sync.js') alert(util_sync.data) document.getElementById(& ...

  7. webpack 配置echarts 按需加载

    引入babel-plugin-equire插件,方便使用.yarn add babel-plugin-equire -D 在.babelrc文件中的配置 { "presets": ...

  8. react-route4 按需加载配置心得

    本篇文章主要记录笔者项目中使用 react-route + webpack 做路由按需加载的心得,可能只有笔者一个人看,权当日记了.   很久很久以前,react-route还是2.X和3.X版本的时 ...

  9. Vue.js中用webpack合并打包多个组件并实现按需加载

    对于现在前端插件的频繁更新,所以多多少少要对组件化有点了解,下面这篇文章主要给大家介绍了在Vue.js中用webpack合并打包多个组件并实现按需加载的相关资料,需要的朋友可以参考下.   前言 随着 ...

随机推荐

  1. ASP.NET Aries 入门开发教程4:查询区的下拉配置

    背景: 今天去深圳溜达了一天,刚回来,看到首页都是微软大法好,看来离.NET的春天就差3个月了~~ 回到正题,这篇的教程讲解下拉配置. 查询区的下拉配置: 1:查询框怎么配置成下拉? 在配置表头:格式 ...

  2. .net core快速上手

    2014年11月12日的Connect ();开发者活动上宣布将.NET堆栈基于MIT协议开源,并且提供开源保证,托管在Github上.当时的版本与最终目标相距甚远,然而有一点可以肯定的是,这是一个与 ...

  3. Laravel 5.x 请求的生命周期(附源码)

    Laravel最早接触是刚开始实习的时候,那时通过网上的学习资料很快便上手,开发模块接口.后来没有什么深入和总结,但是当我刚开始学Laravel的时候,我对Laravel最大的认识就是,框架除了路由. ...

  4. 记录一则Linux SSH的互信配置过程

    需求:四台Linux主机,IP地址为192.168.10.10/11/12/13,配置登录用户的互信 1.各节点ssh-keygen生成RSA密钥和公钥 ssh-keygen -q -t rsa -N ...

  5. java统计字符串单词的个数

    在一些项目中可能需要对一段字符串中的单词进行统计,我在这里写了一个简单的demo,有需要的同学可以拿去看一下. 本人没怎么写个播客,如果有啥说的不对的地方,你来打我啊 不说废话了直接贴代码: 实现代码 ...

  6. StatePattern(状态模式)

    /** * 状态模式 * @author TMAC-J * 状态模式和策略模式很像,其实仔细研究发现完全不一样 * 策略模式各策略之间没有任何关系,独立的 * 状态模式各状态之间接口方法都是一样的 * ...

  7. 【转】Android开发中让你省时省力的方法、类、接口

    转载 http://www.toutiao.com/i6362292864885457410/?tt_from=mobile_qq&utm_campaign=client_share& ...

  8. Win7安装MySQL-5.7.16过程

    1.在C盘新建MYSQL文件夹:2.将mysql-5.7.16-winx64拷贝到C:\MYSQL文件夹下,更名为mysql-5.7.16:3.在mysql-5.7.16目录下,建my.ini文件,内 ...

  9. Raspberry Pi(树莓派)上安装Raspbian(无路由器,无显示器)

    一. 准备工作 1. 树莓派主板 型号:树莓派3 B型 处理器:四核64位ARM Cortex-A53 CPU 内核架构:ARMv8 2. 一张大于8G的TF卡(本人用的是32G的,也作为PiLFS用 ...

  10. 用ffmpeg快速剪切和合并视频

    如果直接找视频剪切和合并视频的软件,通常出来的都是大的视频编辑软件或者是有图形界面的剪切软件,大型一点的功能太多安装麻烦,小型一点的功能可能不齐全. 只是简单的剪切或者一下合并一下,还是ffmpeg这 ...