Grunt-Kmc基于KISSY项目打包

1. Grunt-Kmc 是基于nodejs开发,所以未安装nodeJS,先需要安装nodejs。安装步骤如下:

       1. 下载安装文件,下载地址:http://www.nodejs.org/download/ 如下:

根据操作系统的多少位 下载那个版本。下载完成后,双击:

执行相应的安装,完成后,在终端命令下,做如下操作:

Node 和 npm的版本号,说明都已经安装成功了(注:新版本的node安装文件已经包含了npm,所以现在只需要安装这个node版本的文件就ok)。

2. Grunt安装:客户端安装命令npm install -g grunt-cli (全局安装)。如下图:

如上:安装已完成!

安装完成之后,敲入命令来安装grunt-kmc 如下命令:

npm install grunt-kmc --save-dev 运行后,

如上环境安装完毕。

demo实例演示:

1. 假设我现在有个项目叫demo1,目录结构如下:

其中npminstall.bat 和 i.bat 两个批处理文件不看

注意:我的本地目录结构如下:

在PHP根目录下的KISSYDemo下的gruntKmc下。你们的可以直接放在根目录下都没有问题,这个自己定义的。

2. package.json文件配置:

  1. 如果我项目根目录没有package.json的话,我们可以进入项目文件demo1 在终端命令下 运行 npm init 可以创建一个。

比如我的生成如下:

  上面的package.json名词解释如下:

  package中比较重要的属性解释:

  name:模块名

    description:模块描述

      version:当前模块的版本号

    author:模块作者信息

      contributors:贡献者人员信息

      dependencies:依赖的模块,NPM就是通过这个属性来解决模块之间的依赖问题的

     devDependencies:同上,不过这里的依赖的模块要多些

     keywords:模块关键字,方便你使用npm search查找到它

   repository:模块文件保存地址,那些贡献者们就能下载到它的源码了

     main:其中”main”: “index”,表示Node.js在调用某个模块的时候,将寻找main指向的路径作为模块的接口,在这里Node将寻找同目录下的index文件,并尝试从它那加载模块;如果没有main,Node还是会尝试寻找index.js或者index.node作为包的接口。

     bin:模块的可执行文件路径

     scripts:这个不清楚作什么用?

     dist:模块的指纹,可用来验证模块的完全性。

接着我在根目录下(demo1)下 运行npm install命令 如下:

可以把所有的依赖项提取出来,生成node_modules文件:如下:

3. Gruntfile.js文件。

    在根目录demo1下,如果没有此文件,可以手动新建一个。此文件是对某目录下的文件打包合并成一个js文件。如代码配置如下:

module.exports = function (grunt) {
var task = grunt.task;
// 如果 Gruntfile.js 编码为 gbk,打开此注释
// grunt.file.defaultEncoding = 'gbk';
grunt.initConfig({ // 对build目录进行清理
clean: {
build: {
src: 'build/*'
}
},
pkg : grunt.file.readJSON('package.json'),
//将src目录中的KISSY文件做编译打包,仅解析合并,源文件不需要指定名称
kmc: {
options: {
// depFilePath: 'build/map.js',
comboOnly: false,
fixModuleName:true,
comboMap: false, packages: [
{
name: '<%= pkg.name %>', // 从package.json里面读取name
path: './',
charset:'utf-8',
ignorePackageNameInUri:true
}
]
},
main: {
files: [
{
expand: true,
cwd: 'src/',
// a.js需要打包or生成依赖关系的文件
src: [ 'a.js'],
// 模块最后输出的路径(fixModuleName === true的时候必须配置这个选项,否则源文件的内容会被修改)
dest: 'build/'
}
]
}
},
uglify: {
build: {
src : 'build/a.js',
dest : 'build/a-min.js'
}
}
}); grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-kmc');
grunt.loadNpmTasks('grunt-contrib-uglify'); grunt.registerTask('default', function(type) {
task.run(['clean:build','kmc','uglify:build']);
});
};

将项目下src下的入口文件a.js 合并压缩到build/a.js, build/a-min.js下。

我们可以来运行下:

进入项目demo1先执行: npm install

接着执行: grunt 命令即可。

最后目录生成这样的:如下:

5. 页面如何初始化调用?

   页面只需要引入KISSY源文件和js压缩后的文件如:

<script src="http://g.tbcdn.cn/kissy/k/1.4.0/seed.js?t=20140811" charset="utf-8"></script>

<script src="http://localhost/KISSYDemo/gruntKmc/demo1/build/a-min.js"></script>

接着use下模块即可 如下:

KISSY.use('demo1/src/a',function(){

console.log("111");

});

上面只是 是对同一个包下kissy模块调用,但是如果是在不同的包下,比如demo1包下想调用demo2包下的组件或者模块要如何调用呢?比如demo2包也有一个目录如下:

思路: 根据Grunt-Kmc 打包的第二种方式 先把demo2包下的src所有的文件打包复制到build下,那么build就有和src下一样的目录和文件,且build下模块名提取出来了的。

如下图:

build下的demo2.js 自动生成模块名。

下面是demo2下的Gruntfile.js配置如下:

module.exports = function (grunt) {
var task = grunt.task;
// 如果 Gruntfile.js 编码为 gbk,打开此注释
// grunt.file.defaultEncoding = 'gbk';
grunt.initConfig({ // 对build目录进行清理
clean: {
build: {
src: 'build/*'
}
},
pkg: grunt.file.readJSON('package.json'),
/**
* 将src目录中的KISSY文件做编译打包,仅解析合并,源文件不需要指定名称
* KISSY.add(<名称留空>,function(S){});
*
* @link https://github.com/daxingplay/grunt-kmc
* @link http://docs.kissyui.com/1.4/docs/html/guideline/kmc.html
*/
kmc: {
options: {
// depFilePath: 'build/map.js',
comboOnly: true,
fixModuleName:true,
comboMap: false,
packages: [
{
name: '<%= pkg.name %>',
path: './',
charset:'utf-8',
ignorePackageNameInUri:true
}
]
},
main: {
files: [
{
expand: true,
cwd: 'build/',
// 仅合并这两个文件
src: [ '**/*.js','!map.js'],
dest: 'build/'
}
]
}
},
copy: {
main: {
files: [
{
expand:true,
cwd:'src/',
src: ['**/*.js'], dest: 'build/'}
]
}
}, }); grunt.loadNpmTasks('grunt-contrib-clean');
grunt.loadNpmTasks('grunt-kmc');
grunt.loadNpmTasks('grunt-contrib-copy');
return grunt.registerTask('default', '默认流程', function(type) {
task.run(['clean:build','copy', 'kmc']);
}); };

同样运行命令的方式和上面一样。(进入项目demo2目录中运行npm install  及 grunt)

最终生成如下:

现在我们来看看demo1包下的文件如何来调用demo2包下的模块。比如demo1下的src下c.js文件如下代码:

// c.js
KISSY.add(function (S) {
S.log('c');
return {};
},{requires:['demo2/build/demo2']});

依赖demo2包下的build/demo2.js模块,我们只需要在配置文件改下即可依赖。还是回到我们初始化代码上来index.html:如下:

<script src="http://g.tbcdn.cn/kissy/k/1.4.0/seed.js?t=20140811" charset="utf-8"></script>
<script src="http://localhost/KISSYDemo/gruntKmc/demo1/build/a-min.js"></script>
</head>
<body>
<script>
//KISSY配置针对不同的包名配置
KISSY.config({
// 开启自动 combo 模式
combine:true,
// kissy 库内置模块的时间戳
tag:'2014',
packages:{
demo1:{
// demo1 包的基准路径
base:'http://localhost/KISSYDemo/gruntKmc/',
// demo1 包的时间戳
tag:'20140818',
// 开启 x 包 debug 模式
debug:true
},
demo2:{
// demo2 包的基准路径
base:'http://localhost/KISSYDemo/gruntKmc/',
// demo2s 包不开启自动 combo
combine:false
// 不配置 tag,则取 kissy 内置模块的时间戳
}
}
});
KISSY.use('demo1/src/a',function(){
console.log("111");
});
</script>
</body>

就ok了。如下:我本地测试demo1.

依赖demo2包下的demo2.js   demo2.js 又依赖于demo2包下a.js,a.js又依赖于b.js,c.js。所以就可以看到如上所示的请求。

要想多了解gruntKmc打包的话 可以请看 "紫英童鞋" 的原文,如下:

https://github.com/daxingplay/grunt-kmc

点击这里下载源码

Grunt-Kmc基于KISSY项目打包的更多相关文章

  1. 基于vue-cli项目打包慢的定位优化过程

    入职一周后,上一个前端就离职了(超级坑爹的),留下了一个比较棘手的问题,就是基于vue-cli的项目打包超级慢,我接手项目的时候,打包需要45min(上个离职者也不知道原因),经过3个月之后,随着项目 ...

  2. jar包打包成exe示例(基于maven项目)

    jar包打包成exe示例(基于maven项目) 说明 针对基于maven的Java项目,通常会打包成jar, 如果要把jar文件包装成exe文件,仅需要在pom.xml配置文件中增加一个插件即可 这里 ...

  3. 基于Java的打包jar、war、ear包的作用与区别详解

      本篇文章,小编为大家介绍,基于Java的打包jar.war.ear包的作用与区别详解.需要的朋友参考下   以最终客户的角度来看,JAR文件就是一种封装,他们不需要知道jar文件中有多少个.cla ...

  4. 十二、VueJs 填坑日记之项目打包发布

    通过上一篇博文的学习,我们其实已经完成了我们设想的项目的开发.但是,我们做好的这套东西,是基于 nodejs 开发的.而我们最终希望,我们开发的项目,生成好一堆文件,然后随便通过任何一个 http 服 ...

  5. 将php项目打包docker镜像

    简介:有时候我们需要将php的项目打包成docker镜像,这里介绍下 思路:我们php和apache结合一个镜像实现php项目的访问,mysql是一个单独的镜像 步骤: 1.首先我们在本地测试好自己的 ...

  6. SpringBoot项目打包成jar后,启动脚本

    将springboot项目打包成jar后,上传至服务器,每次都需要手敲命令,重新部署项目,可将这些命令写入脚本中,直接运行. 启动脚本(start.sh): CUR_PATH=$(cd "$ ...

  7. 使用BUCK进行iOS项目打包

    关于BUCK BUCK是Facebook开源的快速打包工具,可以用于多种语言及平台的项目打包,例如:C.C++.Java.iOS.Android等等.用于大型的iOS.Android项目,可以显著提升 ...

  8. ******可用 SpringBoot 项目打包分开lib,配置和资源文件

    spring-boot多模块打包后,无法找到其他模块中的类https://blog.csdn.net/Can96/article/details/96172172 关于SpringBoot项目打包没有 ...

  9. vue项目打包采坑

    1. vue项目打包采坑 1.1. vue运行报错error:Cannot assign to read only property 'exports' of object '#' 这个错误我是在打包 ...

随机推荐

  1. Android - ANR小结

    Application Not Responding 在Android上,如果你的应用程序有一段时间响应不够灵敏,系统会向用户显示一个对话框,这个对话框称作应用程序无响应(ANR:Applicatio ...

  2. mongodb命令(持续更新)

    $lt $lte $gt $gte< . <= . > . >= 1.分组求和db.collection.aggregate([{$group : {_id : null, s ...

  3. apache2.4.33伪静态配置入门教程(1)

    伪静态: 把动态网页的请求方式伪装成静态网页 要使用伪静态技术,要在httpd.conf中启用伪静态模块: LoadModule rewrite_module modules/mod_rewrite. ...

  4. 【学习笔记】--- 老男孩学Python,day3 while 循环 运算符 逻辑、赋值运算

    1. 循环. while循环 while 条件: 代码块(循环体) 执行流程: 1. 判断条件是否为真. 如果真. 执行代码块 2. 再次判断条件是否为真...... 3. 当条件为假.执行else ...

  5. 数据库概念:码 键 Key & 范式 Normal Form

    参考资料 数据库管理系统原理与设计(Database Mangement System 3rd) 百度 wiki 术语对照 码 = 键 = Key 码约束 = Key Constraints 码约束 ...

  6. AsyncTask GET请求

    布局: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android= ...

  7. AIDL安卓接口定义语言

    Android    Interface Definition  Language简称AIDL翻译为 :安卓       接口      定义        语言 AIDL:进程间通信.Android ...

  8. Flutter 图片如何充满父布局

    正常我们需要显示一张图片,会用到Image这个控件.打个比方,我们加载一张本地的图片,先看一下这个Image.asset的源码: Image.asset(String name, { Key key, ...

  9. 大数据【五】Hive(部署;表操作;分区)

    一 概述 就像我们所了解的sql一样,Hive也是一种数据仓库,不同的是hive是在hadoop大数据生态圈中所用.这篇博客我主要介绍Hive的简单表运用. Hive是Hadoop 大数据生态圈中的数 ...

  10. CSS 小结笔记之图标字体(IconFont)

    本篇主要介绍一种非常好用的图标大法——图标字体(IconFont). 什么是图标字体?顾名思义,它是一种字体,只不过这个字体显示的并不是具体的文字之类的,而是各种图标. 网站上经常会用到各种图标,之前 ...