尝试了网上的yeoman generator 生成的脚手架项目不甚理想

npm install -g generator-angular-require

yo angular-require

就不用那个了,如今在github上找来一个细致研究下。

文件夹结构:

符合yeoman脚手架的基本文件夹结构

重点看一下 script下的文件夹结构

main.js

/*jshint unused: vars */
require.config({
baseUrl: '../scripts',
paths: {
underscore: '../bower_components/underscore/underscore',
jquery: '../bower_components/jquery/dist/jquery',
bootstrap: '../bower_components/company-theme.git/src/js/bootstrap/bootstrap',
dcjqaccordion: '../bower_components/company-theme.git/src/js/jquery.dcjqaccordion.2.7',
scrollTo: '../bower_components/company-theme.git/src/js/jquery.scrollTo.min',
nicescroll: '../bower_components/company-theme.git/src/js/jquery.nicescroll',
select: '../bower_components/company-theme.git/src/js/bootstrap-select',
ui: '../bower_components/company-theme.git/src/js/aug-ui',
angular: '../bower_components/angular/angular',
'angular-route': '../bower_components/angular-route/angular-route',
'angular-cookies': '../bower_components/angular-cookies/angular-cookies',
'angular-sanitize': '../bower_components/angular-sanitize/angular-sanitize',
'angular-resource': '../bower_components/angular-resource/angular-resource',
'angular-mocks': '../bower_components/angular-mocks/angular-mocks',
'angular-scenario': '../bower_components/angular-scenario/angular-scenario'
},
shim: {
underscore: {
exports: 'underscore'
},
bootstrap: {
deps: [
'jquery'
],
exports: 'bootstrap'
},
dcjqaccordion: {
deps: [
'jquery'
],
exports: 'dcjqaccordion'
},
scrollTo: {
deps: [
'jquery'
],
exports: 'scrollTo'
},
nicescroll: {
deps: [
'jquery'
],
exports: 'nicescroll'
},
select: {
deps: [
'jquery'
],
exports: 'select'
},
ui: {
deps: [
'dcjqaccordion',
'nicescroll',
'scrollTo',
'select'
],
exports: 'ui'
},
angular: {
deps: [
'jquery'
],
exports: 'angular'
},
'angular-route': [
'angular'
],
'angular-cookies': [
'angular'
],
'angular-sanitize': [
'angular'
],
'angular-resource': [
'angular'
],
'angular-mocks': {
deps: [
'angular'
],
exports: 'angular.mock'
}
},
priority: [
'angular'
]
}); //http://code.angularjs.org/1.2.1/docs/guide/bootstrap#overview_deferred-bootstrap
window.name = 'NG_DEFER_BOOTSTRAP!'; require([
'angular',
'app',
'underscore',
'jquery',
'bootstrap',
'dcjqaccordion',
'scrollTo',
'nicescroll',
'select',
'ui',
'angular-route',
'angular-cookies',
'angular-sanitize',
'angular-resource',
'controllers/rootController',
'services/userService',
'directives/ngbkFocus'
], function(angular, app) {
'use strict';
angular.element().ready(function() {
angular.resumeBootstrap([app.name]);
});
});

main.js主要配置了requirejs的基本配置,包含path和shim的配置,shim是为了配置那些不支持amd规范的配置。

angular.element().ready(function() {

    angular.resumeBootstrap([app.name]);

  });

启动angular,或者能够写成还有一种方法

require(['domReady!'], function (document) {

angular.bootstrap(document, ['app']);

});

这样写须要在path里面配置

'domReady': '../lib/requirejs-domready/domReady',

app.js

define(['angular', 'controllers/controllers',
'services/services', 'filters/filters',
'directives/directives'], function (angular) {
return angular.module('MyApp', ['controllers', 'services','filters', 'directives','ngCookies','ngResource','ngSanitize','ngRoute'])
.config(['$routeProvider',
function($routeProvider) {
$routeProvider.when('/', {
templateUrl: 'views/root.html',
controller: 'RootCtrl'
});
}
]);
});

注意上面的app.name就是MyApp

这个js定义了angular的路由和整个app所以来的模块和服务,比如controllers和services这些是自定义的module须要define是引入controllers/controllers和services/services

另一些angular内置的模块服务比如ngRoute,

注意module的名字要个依赖时写的一样。

service目录下主要放置call api的代码,规范应该是这种。

define(['services/services'],
function(services) {
services.factory('UserService', [
function($http) {
return {
getUser: function() {
return 'testUser';
}
};
}]);
});

自己定义了一个提供userService的module。假设想在controllers里用到这个module能够

define(['controllers/controllers', 'services/userService'],
function(controllers) {
controllers.controller('RootCtrl', ['$scope', 'UserService',
function($scope, UserService,$http) { $scope.name = UserService.getUser();
}]);
});

注意UserService的名字要保持一至。

之所以有三种common的controllers.js 和 services.js 和 filter.js是为了requirejs时方便一些。



GruntFile.js文件

// Generated on 2014-04-25 using generator-angular-require 0.1.13
'use strict'; // # Globbing
// for performance reasons we're only matching one level down:
// 'test/spec/{,*/}*.js'
// use this if you want to recursively match all subfolders:
// 'test/spec/**/*.js' module.exports = function (grunt) { // Load grunt tasks automatically
require('load-grunt-tasks')(grunt); // Time how long tasks take. Can help when optimizing build times
require('time-grunt')(grunt); // Define the configuration for all the tasks
grunt.initConfig({ // Project settings
yeoman: {
// configurable paths
app: require('./bower.json').appPath || 'app',
dist: 'dist'
}, // Watches files for changes and runs tasks based on the changed files
watch: {
js: {
files: ['<%= yeoman.app %>/scripts/{,*/}*.js'],
tasks: ['newer:jshint:all'],
options: {
livereload: true
}
},
jsTest: {
files: ['test/spec/{,*/}*.js'],
tasks: ['newer:jshint:test', 'karma']
},
styles: {
files: ['<%= yeoman.app %>/styles/{,*/}*.css'],
tasks: ['newer:copy:styles', 'autoprefixer']
},
gruntfile: {
files: ['Gruntfile.js']
},
livereload: {
options: {
livereload: '<%= connect.options.livereload %>'
},
files: [
'<%= yeoman.app %>/{,*/}*.html',
'.tmp/styles/{,*/}*.css',
'<%= yeoman.app %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}'
]
},
less: {
files: ['**/*.less'],
tasks: [ 'less'],
options: {
livereload: true
}
}
}, // The actual grunt server settings
connect: {
options: {
port: 9000,
// Change this to '0.0.0.0' to access the server from outside.
hostname: 'localhost',
livereload: 35729
},
livereload: {
options: {
open: true,
base: [
'.tmp',
'<%= yeoman.app %>'
]
}
},
test: {
options: {
port: 9001,
base: [
'.tmp',
'test',
'<%= yeoman.app %>'
]
}
},
dist: {
options: {
base: '<%= yeoman.dist %>'
}
}
}, // Make sure code styles are up to par and there are no obvious mistakes
jshint: {
options: {
jshintrc: '.jshintrc',
reporter: require('jshint-stylish')
},
all: [
'Gruntfile.js',
'<%= yeoman.app %>/scripts/{,*/}*.js'
],
test: {
options: {
jshintrc: 'test/.jshintrc'
},
src: ['test/spec/{,*/}*.js']
}
}, // Empties folders to start fresh
clean: {
dist: {
files: [{
dot: true,
src: [
'.tmp',
'<%= yeoman.dist %>/*',
'!<%= yeoman.dist %>/.git*'
]
}]
},
server: '.tmp'
}, // Add vendor prefixed styles
autoprefixer: {
options: {
browsers: ['last 1 version']
},
dist: {
files: [{
expand: true,
cwd: '.tmp/styles/',
src: '{,*/}*.css',
dest: '.tmp/styles/'
}]
}
}, // Automatically inject Bower components into the app
'bower-install': {
app: {
html: '<%= yeoman.app %>/index.html',
ignorePath: '<%= yeoman.app %>/'
}
}, // Renames files for browser caching purposes
rev: {
dist: {
files: {
src: [
'<%= yeoman.dist %>/scripts/{,*/}*.js',
'<%= yeoman.dist %>/styles/{,*/}*.css',
'<%= yeoman.dist %>/images/{,*/}*.{png,jpg,jpeg,gif,webp,svg}',
'<%= yeoman.dist %>/styles/fonts/*'
]
}
}
}, // Reads HTML for usemin blocks to enable smart builds that automatically
// concat, minify and revision files. Creates configurations in memory so
// additional tasks can operate on them
useminPrepare: {
html: '<%= yeoman.app %>/index.html',
options: {
dest: '<%= yeoman.dist %>'
}
}, // Performs rewrites based on rev and the useminPrepare configuration
usemin: {
html: ['<%= yeoman.dist %>/{,*/}*.html'],
css: ['<%= yeoman.dist %>/styles/{,*/}*.css'],
options: {
assetsDirs: ['<%= yeoman.dist %>']
}
}, // The following *-min tasks produce minified files in the dist folder
imagemin: {
dist: {
files: [{
expand: true,
cwd: '<%= yeoman.app %>/images',
src: '{,*/}*.{png,jpg,jpeg,gif}',
dest: '<%= yeoman.dist %>/images'
}]
}
},
svgmin: {
dist: {
files: [{
expand: true,
cwd: '<%= yeoman.app %>/images',
src: '{,*/}*.svg',
dest: '<%= yeoman.dist %>/images'
}]
}
},
htmlmin: {
dist: {
options: {
collapseWhitespace: true,
collapseBooleanAttributes: true,
removeCommentsFromCDATA: true,
removeOptionalTags: true
},
files: [{
expand: true,
cwd: '<%= yeoman.dist %>',
src: ['*.html', 'views/{,*/}*.html'],
dest: '<%= yeoman.dist %>'
}]
}
}, // Allow the use of non-minsafe AngularJS files. Automatically makes it
// minsafe compatible so Uglify does not destroy the ng references
ngmin: {
dist: {
files: [{
expand: true,
cwd: '.tmp/concat/scripts',
src: '*.js',
dest: '.tmp/concat/scripts'
}]
}
}, // Replace Google CDN references
cdnify: {
dist: {
html: ['<%= yeoman.dist %>/*.html']
}
}, // Copies remaining files to places other tasks can use
copy: {
dist: {
files: [{
expand: true,
dot: true,
cwd: '<%= yeoman.app %>',
dest: '<%= yeoman.dist %>',
src: [
'*.{ico,png,txt}',
'.htaccess',
'*.html',
'views/{,*/}*.html',
'bower_components/requirejs/**/*',
'images/{,*/}*.{webp}',
'fonts/*'
]
}, {
expand: true,
cwd: '.tmp/images',
dest: '<%= yeoman.dist %>/images',
src: ['generated/*']
},
{
expand: true,
dot: true,
cwd: '<%= yeoman.app %>',
dest: '<%= yeoman.dist %>/fonts',
src: ['bower_components/company-theme.git/src/css/fonts/*'],
flatten: true
}]
},
styles: {
expand: true,
cwd: '<%= yeoman.app %>/styles',
dest: '.tmp/styles/',
src: '{,*/}*.css'
}
}, // Run some tasks in parallel to speed up the build process
concurrent: {
server: [
'copy:styles'
],
test: [
'copy:styles'
],
dist: [
'copy:styles',
'imagemin',
'svgmin'
]
}, // By default, your `index.html`'s <!-- Usemin block --> will take care of
// minification. These next options are pre-configured if you do not wish
// to use the Usemin blocks.
cssmin: {
options: {
keepSpecialComments: '0'
},
dist: {
files: {
'<%= yeoman.dist %>/styles/main.css': [
'.tmp/styles/{,*/}*.css',
'<%= yeoman.app %>/styles/{,*/}*.css'
]
}
}
},
// uglify: {
// dist: {
// files: {
// '<%= yeoman.dist %>/scripts/scripts.js': [
// '<%= yeoman.dist %>/scripts/scripts.js'
// ]
// }
// }
// },
// concat: {
// dist: {}
// }, // Test settings
karma: {
unit: {
configFile: 'karma.conf.js',
singleRun: true
}
}, // Settings for grunt-bower-requirejs
bower: {
app: {
rjsConfig: '<%= yeoman.app %>/scripts/main.js',
options: {
exclude: ['requirejs', 'json3', 'es5-shim']
}
}
}, replace: {
test: {
src: '<%= yeoman.app %>/../test/test-main.js',
overwrite: true,
replacements: [{
from: /paths: {[^}]+}/,
to: function() {
return require('fs').readFileSync(grunt.template.process('<%= yeoman.app %>') + '/scripts/main.js').toString().match(/paths: {[^}]+}/);
}
}]
}
}, less: {
dist: {
expand: true,
cwd: "<%= yeoman.app %>/styles",
src: "{,*/}*.less",
dest: ".tmp/styles",
ext: ".css" }
},
// r.js compile config
requirejs: {
dist: {
options: {
dir: "<%= yeoman.dist %>/scripts/",
modules: [{
name: 'main'
}],
preserveLicenseComments: false, // remove all comments
removeCombined: true,
baseUrl: '<%= yeoman.app %>/scripts',
mainConfigFile: '<%= yeoman.app %>/scripts/main.js',
optimize: 'uglify2',
uglify2: {
mangle: false
}
}
}
}
}); grunt.registerTask('serve', function (target) {
if (target === 'dist') {
return grunt.task.run(['build', 'connect:dist:keepalive']);
} grunt.task.run([
'clean:server',
'bower-install',
'concurrent:server',
'autoprefixer',
'connect:livereload',
'less',
'watch'
]);
}); grunt.registerTask('server', function (target) {
grunt.log.warn('The `server` task has been deprecated. Use `grunt serve` to start a server.');
grunt.task.run(['serve:' + target]);
}); grunt.registerTask('test', [
'clean:server',
'concurrent:test',
'autoprefixer',
'connect:test',
'karma'
]); grunt.registerTask('build', [
'clean:dist',
'less',
'bower-install',
'bower:app',
'replace:test',
'useminPrepare',
'concurrent:dist',
'autoprefixer',
'concat',
'ngmin',
'copy:dist',
'cdnify',
'cssmin',
// Below task commented out as r.js (via grunt-contrib-requirejs) will take care of this
// 'uglify',
'requirejs:dist',
'rev',
'usemin',
'htmlmin'
]); grunt.registerTask('default', [
'newer:jshint',
'test',
'build'
]);
};

详细每项的配置能够參考曾经的博客,就不多说了。

angularjs requeirjs配置相关的更多相关文章

  1. Hibernate 系列 04 - Hibernate 配置相关的类

    引导目录: Hibernate 系列教程 目录 前言: 通过上一篇的增删改查小练习之后,咱们大概已经掌握了Hibernate的基本用法. 我们发现,在调用Hibernate API的过程中,虽然Hib ...

  2. AngularJS $http配置为form data 提交

    AngularJS $http配置为form data 提交 $scope.formData = {}; $http({ method: 'POST', url: '/user/', // pass ...

  3. linux网络配置相关命令、虚拟网络接口eth0:0

    网络接口(interface)是网络硬件设备在操作系统中的表示方法,比如网卡在Linux操作系统中用ethX,是由0开始的正整数,比如eth0.eth1...... ethX.而普通猫和ADSL的接口 ...

  4. GBrowse配置相关资料

    GBrowse配置相关资料(形状.颜色.配置.gff3) http://gmod.org/wiki/Glyphs_and_Glyph_Optionshttp://gmod.org/wiki/GBrow ...

  5. memcached的基本命令(安装、卸载、启动、配置相关)

    memcached的基本命令(安装.卸载.启动.配置相关):-p 监听的端口 -l 连接的IP地址, 默认是本机  -d start 启动memcached服务 -d restart 重起memcac ...

  6. linux网络配置相关文件

    网络接口(interface)是网络硬件设备在操作系统中的表示方法,比如网卡在Linux操作系统中用ethX,是由0开始的正整数,比如eth0.eth1...... ethX.而普通猫和ADSL的接口 ...

  7. Tomcat 参数配置相关

    Tomcat参数配置相关 by:授客 QQ:1033553122 目的: 对Tomcat配置的点滴学习总结,主要目的在于分析Tomcat与性能相关的一些参数设置,以便性能调优时选择最优配置   环境: ...

  8. Nginx 参数配置相关

    Nginx参数配置相关 by:授客 QQ:1033553122 目的: 对Nginx配置的点滴学习总结,主要目的在于分析Nginx与性能相关的一些参数设置,以便性能调优时选择最优配置   环境: $ ...

  9. 【树莓派】服务配置相关3:基于Ubuntu Server的服务配置

    该文接续之前写过的两篇: [树莓派]服务配置相关 [树莓派]服务配置相关2:基于RPi Desktop的服务配置 这是我个人用来进行树莓派盒子安装配置的脚本,对于外部其他博友,可以部分参考,但不需要逐 ...

随机推荐

  1. 【ajax 提交表单】多种方式的注意事项 ,serialize()的使用

    在业务中,可能因为表单内容过于庞大,字段过于繁杂,如果人为去拼接的话 ,需要耗费大量的时间和精力,与此同时,代码看上去也是冗余不堪. 所以,提交表单的时候如果能整个表单数据整体提交,那是非常开心的事情 ...

  2. Java垃圾回收精粹 — Part2

    Java垃圾回收精粹分4个部分,本篇是第2部分.在第2部分里介绍了Hotspot中的堆结构.对象分配以及次要回收. Hotspot中的堆结构 理解不同的收集器的工作方式,是探讨Java堆结构如何支持分 ...

  3. OpenCV Shi-Tomasi角点检测子

    Shi-Tomasi角点检测子 目标 在这个教程中我们将涉及: 使用函数 goodFeaturesToTrack 来调用Shi-Tomasi方法检测角点. 理论 代码 这个教程的代码如下所示.源代码还 ...

  4. OpenCV学习(14) 细化算法(2)

          前面一篇教程中,我们实现了Zhang的快速并行细化算法,从算法原理上,我们可以知道,算法是基于像素8邻域的形状来决定是否删除当前像素.还有很多与此算法相似的细化算法,只是判断的条件不一样. ...

  5. 如何更改postgresql的最大连接数

    改文件 postgresql.conf 里的 #max_connections=32 为 max_connections=1024 以及另外相应修改 share_buffer 参数.

  6. exchange 升级顺序导致的邮件被发不出的问题?

    最近在做一个项目POC,准备升级过程目前的2007 环境到exchange 2010,由于客户环境是exchange 2007 sp1 不满足升级的基本条件,我们必须将exchange 2007 sp ...

  7. 触摸事件【MotionEvent】简介

    MotionEvent简介 当用户触摸屏幕时,将创建一个MontionEvent对象,MotionEvent包含了关于发生触摸的位置.时间信息,以及触摸事件的其他很多细节. Android 将所有的输 ...

  8. drawable和values的加载规则

    Google搞了一大套hdpi.xhdpi之类的这些东西,简单说来,就是为了让我们轻松实现"与设备密度无关的视觉大小一致性",注意这里的"视觉大小一致性",就是 ...

  9. 搜索引擎爬虫蜘蛛的useragent

    百度爬虫    * Baiduspider+(+http://www.baidu.com/search/spider.htm”) google爬虫    * Mozilla/5.0 (compatib ...

  10. Yii学习笔记之二(使用gii生成一个简单的样例)

    1. 数据库准备 (1) 首先我们建一数据库 yii2test 并建立一张表例如以下: DROP TABLE IF EXISTS `posts`; CREATE TABLE `posts` ( `po ...