gpt4 book ai didi

node.js - 带有 grunt 的 Concat bower 组件

转载 作者:IT老高 更新时间:2023-10-28 23:13:10 26 4
gpt4 key购买 nike

我正在构建一个需要少量前端库/框架的应用程序,例如:

  • jQuery
  • JQueryUI
  • AngularJS
  • 基金会

我正在使用 bower 下载组件。此时我的 HTML 看起来像:

<script src="components/jquery/jquery.js"></script>
<script src="components/angular/angular.js"></script>
<script src="components/etc/etc.js"></script>

我的目标是制作一个 grunt 脚本,它会自动获取已安装的组件,合并并缩小它们并将它们输出为 lib.js

问题:

通过我的所有研究,我弄清楚了如何连接目录中的所有文件。我的目标是获取 bower 组件并将它们连接起来,而不是在 gruntfile 中一一列出。我该如何存档?

是否可以只使用我想要的模块而不是拥有整个 UI 来构建自定义 jQuery UI。

谢谢。

最佳答案

usemin是你的 friend 吗。

安装 usemin、复制、concat 和 uglify:

npm install --save-dev grunt-usemin
npm install --save-dev grunt-contrib-copy
npm install --save-dev grunt-contrib-concat
npm install --save-dev grunt-contrib-uglify

在您的 HTML 文件中设置构建 block :

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>usemin</title>
<!-- build:js lib.js -->
<script src="components/jquery/jquery.js"></script>
<script src="components/angular/angular.js"></script>
<script src="components/etc/etc.js"></script>
<!-- endbuild -->
</head>
<body>
<h1>usemin</h1>
</body>
</html>

设置您的 Gruntfile:

module.exports = function(grunt) {
grunt.initConfig({
pkg: grunt.file.readJSON('package.json'),

copy: {
dist: {
files: [ {src: 'index.html', dest: 'dist/index.html'} ]
}
},

'useminPrepare': {
options: {
dest: 'dist'
},
html: 'index.html'
},

usemin: {
html: ['dist/index.html']
}
});

grunt.loadNpmTasks('grunt-contrib-uglify');
grunt.loadNpmTasks('grunt-contrib-copy');
grunt.loadNpmTasks('grunt-contrib-concat');
grunt.loadNpmTasks('grunt-usemin');

grunt.registerTask('default', ['useminPrepare', 'copy', 'concat', 'uglify', 'usemin']);
};

咕噜声

grunt

结果:

├── Gruntfile.js
├── components
│   ├── angular
│   │   └── angular.js
│   ├── etc
│   │   └── etc.js
│   └── jquery
│   └── jquery.js
├── dist
│   ├── index.html
│   └── lib.js
├── index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>usemin</title>
<script src="lib.js"></script>
</head>
<body>
<h1>usemin</h1>
</body>
</html>

关于node.js - 带有 grunt 的 Concat bower 组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21148042/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com