├── .babelrc ├── .editorconfig ├── .gitignore ├── .jshintrc ├── .vscode └── launch.json ├── LICENSE ├── README.md ├── config.js ├── data ├── data.js └── index.js ├── gulpfile.js ├── package.json ├── public ├── css │ └── main.css └── js │ └── index.js ├── sass ├── _config.scss ├── _global.sass ├── _mixins.scss ├── includes │ ├── _footer.scss │ └── _header.scss ├── main.scss └── pages │ └── index.scss ├── server.js └── views ├── error.pug ├── includes ├── footer.pug └── header.pug ├── index.pug └── layout └── layout.pug /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": ["es2015"] 3 | } 4 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_style = space 5 | indent_size = 2 6 | end_of_line = lf 7 | charset = utf-8 8 | trim_trailing_whitespace = true 9 | insert_final_newline = true 10 | [*.md] 11 | trim_trailing_whitespace = false 12 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | ### Example user template template 2 | ### Example user template 3 | 4 | # IntelliJ project files 5 | .idea 6 | gen 7 | # Created by .ignore support plugin (hsz.mobi) 8 | node_modules 9 | -------------------------------------------------------------------------------- /.jshintrc: -------------------------------------------------------------------------------- 1 | { 2 | /* 3 | * ENVIRONMENTS 4 | * ================= 5 | */ 6 | 7 | // Define globals exposed by modern browsers. 8 | "browser": true, 9 | 10 | // Define globals exposed by jQuery. 11 | "jquery": true, 12 | 13 | // Define globals exposed by Node.js. 14 | "node": true, 15 | 16 | // Allow ES6. 17 | "esnext": true, 18 | 19 | /* 20 | * ENFORCING OPTIONS 21 | * ================= 22 | */ 23 | 24 | // Force all variable names to use either camelCase style or UPPER_CASE 25 | // with underscores. 26 | "camelcase": true, 27 | 28 | // Prohibit use of == and != in favor of === and !==. 29 | "eqeqeq": true, 30 | 31 | // Enforce tab width of 2 spaces. 32 | "indent": 2, 33 | 34 | // Prohibit use of a variable before it is defined. 35 | "latedef": true, 36 | 37 | // Enforce line length to 80 characters 38 | "maxlen": 80, 39 | 40 | // Require capitalized names for constructor functions. 41 | "newcap": true, 42 | 43 | // Enforce use of single quotation marks for strings. 44 | "quotmark": "single", 45 | 46 | // Enforce placing 'use strict' at the top function scope 47 | "strict": true, 48 | 49 | // Prohibit use of explicitly undeclared variables. 50 | "undef": true, 51 | 52 | // Warn when variables are defined but never used. 53 | "unused": true, 54 | 55 | /* 56 | * RELAXING OPTIONS 57 | * ================= 58 | */ 59 | 60 | // Suppress warnings about == null comparisons. 61 | "eqnull": true 62 | } 63 | -------------------------------------------------------------------------------- /.vscode/launch.json: -------------------------------------------------------------------------------- 1 | { 2 | "version": "0.2.0", 3 | "configurations": [ 4 | { 5 | "name": "Launch", 6 | "type": "node", 7 | "request": "launch", 8 | "program": "${workspaceRoot}/server.js", 9 | "stopOnEntry": false, 10 | "args": [], 11 | "cwd": "${workspaceRoot}", 12 | "preLaunchTask": null, 13 | "runtimeExecutable": null, 14 | "runtimeArgs": [ 15 | "--nolazy" 16 | ], 17 | "env": { 18 | "NODE_ENV": "development" 19 | }, 20 | "externalConsole": false, 21 | "sourceMaps": false, 22 | "outDir": null 23 | }, 24 | { 25 | "name": "Attach", 26 | "type": "node", 27 | "request": "attach", 28 | "port": 5858, 29 | "address": "localhost", 30 | "restart": false, 31 | "sourceMaps": false, 32 | "outDir": null, 33 | "localRoot": "${workspaceRoot}", 34 | "remoteRoot": null 35 | }, 36 | { 37 | "name": "Attach to Process", 38 | "type": "node", 39 | "request": "attach", 40 | "processId": "${command.PickProcess}", 41 | "port": 5858, 42 | "sourceMaps": false, 43 | "outDir": null 44 | } 45 | ] 46 | } 47 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | The MIT License (MIT) 2 | 3 | Copyright (c) 2015 抹桥 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | 23 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Express+BrowserSync+nodemon 2 | 3 | ## 使用(Use) 4 | ```bash 5 | npm install 6 | ``` 7 | 8 | ## 开发(dev) 9 | ```bash 10 | npm run dev 11 | ``` 12 | Express 会被 BrowserSync 代理到 5000 端口,同时提供本地 mock 功能, mock 数据存放在 data/data.js 里面,简单粗暴,就是一个 JSON 对象。当然也可以在 server 的 data/index.js 里面自定义更加详细的数据返回。 13 | ## 联调(dev api) 14 | ```bash 15 | npm run api 16 | ``` 17 | 在上一个命令的基础上,把 mock 数据由本地换为实际服务器地址,可以在 config.js 下面配置 18 | ```javascript 19 | module.exports = { 20 | 'port': 3000, 21 | 'remoteApi': '10.240.96.129:3008' //服务器地址 22 | } 23 | ``` 24 | ## 构建(dist) 25 | ```bash 26 | npm run dist 27 | ``` 28 | 打包压缩后的文件会存放在 public 文件夹下。 29 | 30 | Browser to localhost:5000 ,go dev! 31 | -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | 'port': 3000, 3 | 'remoteApi': '10.240.96.129:3008' 4 | } 5 | -------------------------------------------------------------------------------- /data/data.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | '/loansss':{ 3 | 'name':'NetEase', 4 | 'age':'19', 5 | 'des':'HAHA' 6 | }, 7 | '/psddn': { 8 | "code": 0, 9 | "data": { 10 | "sss": true, 11 | }, 12 | "sss": "123", 13 | "redirect": 0 14 | }, 15 | '/loan/po': { 16 | 'pro': 'haha' 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /data/index.js: -------------------------------------------------------------------------------- 1 | var forceRequire = require('require-reload') 2 | 3 | module.exports = function (router) { 4 | var data = forceRequire('./data') 5 | //每隔1秒重新解析data,刷新data,新增的路由不会生效 6 | setInterval(function () { 7 | data = forceRequire('./data') 8 | }, 1000) 9 | 10 | for (var i in data) { 11 | (function (v) { 12 | router.get(v, function (req, res) { 13 | res.json( 14 | data[v] 15 | ) 16 | }) 17 | router.post(v, function (req, res) { 18 | res.json( 19 | data[v] 20 | ) 21 | }) 22 | })(i) 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /gulpfile.js: -------------------------------------------------------------------------------- 1 | // Modules dependencies 2 | var gulp = require('gulp') 3 | var sass = require('gulp-sass') 4 | var sourcemaps = require('gulp-sourcemaps') 5 | var browserSync = require('browser-sync') 6 | var bs = browserSync.create('My server') 7 | var nodemon = require('gulp-nodemon') 8 | var cssnano = require('gulp-cssnano') 9 | var uglify = require('gulp-uglify') 10 | var rename = require('gulp-rename') 11 | var config = require('./config') 12 | var path = require('path') 13 | 14 | // path 定义 15 | var basedir = './' 16 | var publicdir = './public' 17 | var filepath = { 18 | 'css': path.join(publicdir, 'css/**/*.css'), 19 | 'scss': path.join(basedir, 'sass/**/*.scss'), 20 | 'js': path.join(publicdir, 'js/**/*.js'), 21 | 'view': path.join(basedir,'views/**/*.pug') 22 | } 23 | 24 | // 编译 scss 25 | gulp.task('css', function () { 26 | return gulp.src(path.join(basedir,'sass/main.scss')) 27 | .pipe(sourcemaps.init()) 28 | .pipe(sass().on('error', sass.logError)) 29 | .pipe(sourcemaps.write()) 30 | .pipe(gulp.dest(path.join(publicdir,'css'))) 31 | .pipe(bs.stream()) 32 | }) 33 | 34 | // dev server 35 | // 启动 express 并添加 browserSync 支持 36 | gulp.task('dev:server', function () { 37 | nodemon({ 38 | script: 'server.js', 39 | ignore: ['.vscode', '.idea', 'node_modules'], 40 | env: { 41 | 'NODE_ENV': 'development' 42 | } 43 | }) 44 | bs.init(null, { 45 | proxy: 'http://localhost:' + config.port, 46 | files: [filepath.js, filepath.view], 47 | notify: false, 48 | open: true, 49 | port: 5000 50 | }) 51 | }) 52 | 53 | 54 | 55 | // 联调服务 56 | gulp.task('api:server', function () { 57 | nodemon({ 58 | script: 'server.js', 59 | ignore: ['.vscode', '.idea', 'node_modules'], 60 | env: { 61 | 'NODE_ENV': 'api', 62 | 'REMOTE_API': config.remoteApi 63 | } 64 | }) 65 | bs.init(null, { 66 | proxy: 'http://localhost:' + config.port, 67 | files: [filepath.js, filepath.view], 68 | notify: false, 69 | open: false, 70 | port: 5000 71 | }) 72 | }) 73 | 74 | gulp.task('cssmin', function () { 75 | return gulp.src(path.join(publicdir,'css/main.css')) 76 | .pipe(cssnano()) 77 | .pipe(rename({ 78 | suffix: '.min' 79 | })) 80 | .pipe(gulp.dest(path.join(publicdir,'css'))) 81 | }) 82 | 83 | gulp.task('jsmin', function () { 84 | return gulp.src(filepath.js) 85 | .pipe(uglify()) 86 | .pipe(rename({ 87 | suffix: '.min' 88 | })) 89 | .pipe(gulp.dest(path.join(publicdir,'js'))) 90 | }) 91 | 92 | gulp.task('build', ['cssmin', 'jsmin']) 93 | 94 | // watching 95 | gulp.task('watch', function () { 96 | gulp.watch(filepath.scss, ['css']) 97 | }) 98 | 99 | gulp.task('dev', ['dev:server', 'css', 'watch']) 100 | gulp.task('api', ['api:server', 'css', 'watch']) 101 | 102 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "Express-Gulp-BrowserSync", 3 | "version": "0.1.1", 4 | "private": true, 5 | "scripts": { 6 | "dev": "gulp dev", 7 | "api": "gulp api", 8 | "dist": "gulp build" 9 | }, 10 | "author": { 11 | "name": "kisnows", 12 | "email": "yq12315@gmail.com", 13 | "url": "https://github.com/kisnows/Express-Gulp-BrowserSync" 14 | }, 15 | "devDependencies": { 16 | "browser-sync": "^2.13.0", 17 | "chalk": "^1.1.3", 18 | "express": "^4.14.0", 19 | "gulp": "^3.9.1", 20 | "gulp-cssnano": "^2.1.2", 21 | "gulp-nodemon": "^2.1.0", 22 | "gulp-rename": "^1.2.2", 23 | "gulp-sass": "^2.3.2", 24 | "gulp-sourcemaps": "^1.6.0", 25 | "gulp-uglify": "^1.5.4", 26 | "normalize.css": "^4.2.0", 27 | "pug": "^2.0.0-beta3", 28 | "request": "^2.73.0", 29 | "require-reload": "^0.2.2", 30 | "serve-favicon": "^2.3.0" 31 | } 32 | } 33 | -------------------------------------------------------------------------------- /public/css/main.css: -------------------------------------------------------------------------------- 1 | /*! normalize.css v3.0.2 | MIT License | git.io/normalize */ 2 | html { 3 | font-family: sans-serif; 4 | -ms-text-size-adjust: 100%; 5 | -webkit-text-size-adjust: 100%; } 6 | 7 | body { 8 | margin: 0; } 9 | 10 | article, 11 | aside, 12 | details, 13 | figcaption, 14 | figure, 15 | footer, 16 | header, 17 | hgroup, 18 | main, 19 | menu, 20 | nav, 21 | section, 22 | summary { 23 | display: block; } 24 | 25 | audio, 26 | canvas, 27 | progress, 28 | video { 29 | display: inline-block; 30 | vertical-align: baseline; } 31 | 32 | audio:not([controls]) { 33 | display: none; 34 | height: 0; } 35 | 36 | [hidden], 37 | template { 38 | display: none; } 39 | 40 | a { 41 | background-color: transparent; } 42 | 43 | a:active, 44 | a:hover { 45 | outline: 0; } 46 | 47 | abbr[title] { 48 | border-bottom: 1px dotted; } 49 | 50 | b, 51 | strong { 52 | font-weight: bold; } 53 | 54 | dfn { 55 | font-style: italic; } 56 | 57 | h1 { 58 | font-size: 2em; 59 | margin: 0.67em 0; } 60 | 61 | mark { 62 | background: #ff0; 63 | color: #000; } 64 | 65 | small { 66 | font-size: 80%; } 67 | 68 | sub, 69 | sup { 70 | font-size: 75%; 71 | line-height: 0; 72 | position: relative; 73 | vertical-align: baseline; } 74 | 75 | sup { 76 | top: -0.5em; } 77 | 78 | sub { 79 | bottom: -0.25em; } 80 | 81 | img { 82 | border: 0; } 83 | 84 | svg:not(:root) { 85 | overflow: hidden; } 86 | 87 | figure { 88 | margin: 1em 40px; } 89 | 90 | hr { 91 | -moz-box-sizing: content-box; 92 | box-sizing: content-box; 93 | height: 0; } 94 | 95 | pre { 96 | overflow: auto; } 97 | 98 | code, 99 | kbd, 100 | pre, 101 | samp { 102 | font-family: monospace, monospace; 103 | font-size: 1em; } 104 | 105 | button, 106 | input, 107 | optgroup, 108 | select, 109 | textarea { 110 | color: inherit; 111 | font: inherit; 112 | margin: 0; } 113 | 114 | button { 115 | overflow: visible; } 116 | 117 | button, 118 | select { 119 | text-transform: none; } 120 | 121 | button, 122 | html input[type="button"], 123 | input[type="reset"], 124 | input[type="submit"] { 125 | -webkit-appearance: button; 126 | cursor: pointer; } 127 | 128 | button[disabled], 129 | html input[disabled] { 130 | cursor: default; } 131 | 132 | button::-moz-focus-inner, 133 | input::-moz-focus-inner { 134 | border: 0; 135 | padding: 0; } 136 | 137 | input { 138 | line-height: normal; } 139 | 140 | input[type="checkbox"], 141 | input[type="radio"] { 142 | box-sizing: border-box; 143 | padding: 0; } 144 | 145 | input[type="number"]::-webkit-inner-spin-button, 146 | input[type="number"]::-webkit-outer-spin-button { 147 | height: auto; } 148 | 149 | input[type="search"] { 150 | -webkit-appearance: textfield; 151 | -moz-box-sizing: content-box; 152 | -webkit-box-sizing: content-box; 153 | box-sizing: content-box; } 154 | 155 | input[type="search"]::-webkit-search-cancel-button, 156 | input[type="search"]::-webkit-search-decoration { 157 | -webkit-appearance: none; } 158 | 159 | fieldset { 160 | border: 1px solid #c0c0c0; 161 | margin: 0 2px; 162 | padding: 0.35em 0.625em 0.75em; } 163 | 164 | legend { 165 | border: 0; 166 | padding: 0; } 167 | 168 | textarea { 169 | overflow: auto; } 170 | 171 | optgroup { 172 | font-weight: bold; } 173 | 174 | table { 175 | border-collapse: collapse; 176 | border-spacing: 0; } 177 | 178 | td, 179 | th { 180 | padding: 0; } 181 | 182 | body { 183 | line-height: 1.5; 184 | font-size: 14px; 185 | font-family: Tahoma, Arial, "Microsoft YaHei", sans-serif; 186 | color: #979798; } 187 | 188 | .content { 189 | width: 1200px; 190 | margin: 0 auto; } 191 | 192 | a { 193 | text-decoration: none; } 194 | 195 | li { 196 | list-style: none; } 197 | 198 | .page-index h1 { 199 | color: red; } 200 | 201 | /*# sourceMappingURL=data:application/json;base64,{"version":3,"file":"main.css","sources":["main.scss","_normalize.scss","_mixins.scss","_config.scss","_global.sass","includes/_header.scss","includes/_footer.scss","pages/index.scss"],"sourcesContent":["@import 'normalize';\n@import 'mixins';\n@import 'config';\n\n@import 'global';\n//includes\n@import 'includes/_header';\n@import 'includes/_footer';\n\n//pages\n@import 'pages/index';\n","/*! normalize.css v3.0.2 | MIT License | git.io/normalize */\r\n\r\n//\r\n// 1. Set default font family to sans-serif.\r\n// 2. Prevent iOS text size adjust after orientation change, without disabling\r\n//    user zoom.\r\n//\r\n\r\nhtml {\r\n  font-family: sans-serif; // 1\r\n  -ms-text-size-adjust: 100%; // 2\r\n  -webkit-text-size-adjust: 100%; // 2\r\n}\r\n\r\n//\r\n// Remove default margin.\r\n//\r\n\r\nbody {\r\n  margin: 0;\r\n}\r\n\r\n// HTML5 display definitions\r\n// ==========================================================================\r\n\r\n//\r\n// Correct `block` display not defined for any HTML5 element in IE 8/9.\r\n// Correct `block` display not defined for `details` or `summary` in IE 10/11\r\n// and Firefox.\r\n// Correct `block` display not defined for `main` in IE 11.\r\n//\r\n\r\n//noinspection ALL\r\narticle,\r\naside,\r\ndetails,\r\nfigcaption,\r\nfigure,\r\nfooter,\r\nheader,\r\nhgroup,\r\nmain,\r\nmenu,\r\nnav,\r\nsection,\r\nsummary {\r\n  display: block;\r\n}\r\n\r\n//\r\n// 1. Correct `inline-block` display not defined in IE 8/9.\r\n// 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.\r\n//\r\n\r\naudio,\r\ncanvas,\r\nprogress,\r\nvideo {\r\n  display: inline-block; // 1\r\n  vertical-align: baseline; // 2\r\n}\r\n\r\n//\r\n// Prevent modern browsers from displaying `audio` without controls.\r\n// Remove excess height in iOS 5 devices.\r\n//\r\n\r\naudio:not([controls]) {\r\n  display: none;\r\n  height: 0;\r\n}\r\n\r\n//\r\n// Address `[hidden]` styling not present in IE 8/9/10.\r\n// Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.\r\n//\r\n\r\n[hidden],\r\ntemplate {\r\n  display: none;\r\n}\r\n\r\n// Links\r\n// ==========================================================================\r\n\r\n//\r\n// Remove the gray background color from active links in IE 10.\r\n//\r\n\r\na {\r\n  background-color: transparent;\r\n}\r\n\r\n//\r\n// Improve readability when focused and also mouse hovered in all browsers.\r\n//\r\n\r\na:active,\r\na:hover {\r\n  outline: 0;\r\n}\r\n\r\n// Text-level semantics\r\n// ==========================================================================\r\n\r\n//\r\n// Address styling not present in IE 8/9/10/11, Safari, and Chrome.\r\n//\r\n\r\nabbr[title] {\r\n  border-bottom: 1px dotted;\r\n}\r\n\r\n//\r\n// Address style set to `bolder` in Firefox 4+, Safari, and Chrome.\r\n//\r\n\r\nb,\r\nstrong {\r\n  font-weight: bold;\r\n}\r\n\r\n//\r\n// Address styling not present in Safari and Chrome.\r\n//\r\n\r\ndfn {\r\n  font-style: italic;\r\n}\r\n\r\n//\r\n// Address variable `h1` font-size and margin within `section` and `article`\r\n// contexts in Firefox 4+, Safari, and Chrome.\r\n//\r\n\r\nh1 {\r\n  font-size: 2em;\r\n  margin: 0.67em 0;\r\n}\r\n\r\n//\r\n// Address styling not present in IE 8/9.\r\n//\r\n\r\nmark {\r\n  background: #ff0;\r\n  color: #000;\r\n}\r\n\r\n//\r\n// Address inconsistent and variable font size in all browsers.\r\n//\r\n\r\nsmall {\r\n  font-size: 80%;\r\n}\r\n\r\n//\r\n// Prevent `sub` and `sup` affecting `line-height` in all browsers.\r\n//\r\n\r\nsub,\r\nsup {\r\n  font-size: 75%;\r\n  line-height: 0;\r\n  position: relative;\r\n  vertical-align: baseline;\r\n}\r\n\r\nsup {\r\n  top: -0.5em;\r\n}\r\n\r\nsub {\r\n  bottom: -0.25em;\r\n}\r\n\r\n// Embedded content\r\n// ==========================================================================\r\n\r\n//\r\n// Remove border when inside `a` element in IE 8/9/10.\r\n//\r\n\r\nimg {\r\n  border: 0;\r\n}\r\n\r\n//\r\n// Correct overflow not hidden in IE 9/10/11.\r\n//\r\n\r\nsvg:not(:root) {\r\n  overflow: hidden;\r\n}\r\n\r\n// Grouping content\r\n// ==========================================================================\r\n\r\n//\r\n// Address margin not present in IE 8/9 and Safari.\r\n//\r\n\r\nfigure {\r\n  margin: 1em 40px;\r\n}\r\n\r\n//\r\n// Address differences between Firefox and other browsers.\r\n//\r\n\r\nhr {\r\n  -moz-box-sizing: content-box;\r\n  box-sizing: content-box;\r\n  height: 0;\r\n}\r\n\r\n//\r\n// Contain overflow in all browsers.\r\n//\r\n\r\npre {\r\n  overflow: auto;\r\n}\r\n\r\n//\r\n// Address odd `em`-unit font size rendering in all browsers.\r\n//\r\n\r\ncode,\r\nkbd,\r\npre,\r\nsamp {\r\n  font-family: monospace, monospace;\r\n  font-size: 1em;\r\n}\r\n\r\n// Forms\r\n// ==========================================================================\r\n\r\n//\r\n// Known limitation: by default, Chrome and Safari on OS X allow very limited\r\n// styling of `select`, unless a `border` property is set.\r\n//\r\n\r\n//\r\n// 1. Correct color not being inherited.\r\n//    Known issue: affects color of disabled elements.\r\n// 2. Correct font properties not being inherited.\r\n// 3. Address margins set differently in Firefox 4+, Safari, and Chrome.\r\n//\r\n\r\nbutton,\r\ninput,\r\noptgroup,\r\nselect,\r\ntextarea {\r\n  color: inherit; // 1\r\n  font: inherit; // 2\r\n  margin: 0; // 3\r\n}\r\n\r\n//\r\n// Address `overflow` set to `hidden` in IE 8/9/10/11.\r\n//\r\n\r\nbutton {\r\n  overflow: visible;\r\n}\r\n\r\n//\r\n// Address inconsistent `text-transform` inheritance for `button` and `select`.\r\n// All other form control elements do not inherit `text-transform` values.\r\n// Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.\r\n// Correct `select` style inheritance in Firefox.\r\n//\r\n\r\nbutton,\r\nselect {\r\n  text-transform: none;\r\n}\r\n\r\n//\r\n// 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\r\n//    and `video` controls.\r\n// 2. Correct inability to style clickable `input` types in iOS.\r\n// 3. Improve usability and consistency of cursor style between image-type\r\n//    `input` and others.\r\n//\r\n\r\nbutton,\r\nhtml input[type=\"button\"], // 1\r\ninput[type=\"reset\"],\r\ninput[type=\"submit\"] {\r\n  -webkit-appearance: button; // 2\r\n  cursor: pointer; // 3\r\n}\r\n\r\n//\r\n// Re-set default cursor for disabled elements.\r\n//\r\n\r\nbutton[disabled],\r\nhtml input[disabled] {\r\n  cursor: default;\r\n}\r\n\r\n//\r\n// Remove inner padding and border in Firefox 4+.\r\n//\r\n\r\nbutton::-moz-focus-inner,\r\ninput::-moz-focus-inner {\r\n  border: 0;\r\n  padding: 0;\r\n}\r\n\r\n//\r\n// Address Firefox 4+ setting `line-height` on `input` using `!important` in\r\n// the UA stylesheet.\r\n//\r\n\r\ninput {\r\n  line-height: normal;\r\n}\r\n\r\n//\r\n// It's recommended that you don't attempt to style these elements.\r\n// Firefox's implementation doesn't respect box-sizing, padding, or width.\r\n//\r\n// 1. Address box sizing set to `content-box` in IE 8/9/10.\r\n// 2. Remove excess padding in IE 8/9/10.\r\n//\r\n\r\ninput[type=\"checkbox\"],\r\ninput[type=\"radio\"] {\r\n  box-sizing: border-box; // 1\r\n  padding: 0; // 2\r\n}\r\n\r\n//\r\n// Fix the cursor style for Chrome's increment/decrement buttons. For certain\r\n// `font-size` values of the `input`, it causes the cursor style of the\r\n// decrement button to change from `default` to `text`.\r\n//\r\n\r\ninput[type=\"number\"]::-webkit-inner-spin-button,\r\ninput[type=\"number\"]::-webkit-outer-spin-button {\r\n  height: auto;\r\n}\r\n\r\n//\r\n// 1. Address `appearance` set to `searchfield` in Safari and Chrome.\r\n// 2. Address `box-sizing` set to `border-box` in Safari and Chrome\r\n//    (include `-moz` to future-proof).\r\n//\r\n\r\ninput[type=\"search\"] {\r\n  -webkit-appearance: textfield; // 1\r\n  -moz-box-sizing: content-box;\r\n  -webkit-box-sizing: content-box; // 2\r\n  box-sizing: content-box;\r\n}\r\n\r\n//\r\n// Remove inner padding and search cancel button in Safari and Chrome on OS X.\r\n// Safari (but not Chrome) clips the cancel button when the search input has\r\n// padding (and `textfield` appearance).\r\n//\r\n\r\ninput[type=\"search\"]::-webkit-search-cancel-button,\r\ninput[type=\"search\"]::-webkit-search-decoration {\r\n  -webkit-appearance: none;\r\n}\r\n\r\n//\r\n// Define consistent border, margin, and padding.\r\n//\r\n\r\nfieldset {\r\n  border: 1px solid #c0c0c0;\r\n  margin: 0 2px;\r\n  padding: 0.35em 0.625em 0.75em;\r\n}\r\n\r\n//\r\n// 1. Correct `color` not being inherited in IE 8/9/10/11.\r\n// 2. Remove padding so people aren't caught out if they zero out fieldsets.\r\n//\r\n\r\nlegend {\r\n  border: 0; // 1\r\n  padding: 0; // 2\r\n}\r\n\r\n//\r\n// Remove default vertical scrollbar in IE 8/9/10/11.\r\n//\r\n\r\ntextarea {\r\n  overflow: auto;\r\n}\r\n\r\n//\r\n// Don't inherit the `font-weight` (applied by a rule above).\r\n// NOTE: the default cannot safely be changed in Chrome and Safari on OS X.\r\n//\r\n\r\noptgroup {\r\n  font-weight: bold;\r\n}\r\n\r\n// Tables\r\n// ==========================================================================\r\n\r\n//\r\n// Remove most spacing between table cells.\r\n//\r\n\r\ntable {\r\n  border-collapse: collapse;\r\n  border-spacing: 0;\r\n}\r\n\r\ntd,\r\nth {\r\n  padding: 0;\r\n}\r\n","@mixin size($w, $h) {\r\n  width: $w;\r\n  height: $h;\r\n}\r\n\r\n@mixin image-url($path) {\r\n  background-image: url('./images/#{$path}');\r\n}\r\n\r\n@mixin clearfix {\r\n  &:after {\r\n    content: \"\";\r\n    display: table;\r\n    clear: both;\r\n  }\r\n  *zoom: 1;\r\n}\r\n\r\n@mixin float($direction) {\r\n  float: $direction;\r\n  *display: inline;\r\n}\r\n\r\n@mixin opacity($opacity) {\r\n  filter: unquote(\"progid:DXImageTransform.Microsoft.Alpha(Opacity=#{round($opacity * 100)})\");\r\n  opacity: $opacity;\r\n}\r\n\r\n// Make an element completely transparent.\r\n@mixin transparent { @include opacity(0); }\r\n\r\n@mixin text-overflow {\r\n  max-width     : 100%;\r\n  overflow      : hidden;\r\n  text-overflow : ellipsis;\r\n  white-space   : nowrap;\r\n}\r\n\r\n@mixin word-break {\r\n  word-break  : break-all;\r\n  word-wrap   : break-word;\r\n  white-space : normal;\r\n}\r\n\r\n@mixin border-radius($radius) {\r\n  -webkit-border-radius   : $radius;\r\n  -moz-border-radius      : $radius;\r\n  border-radius           : $radius;\r\n}\r\n\r\n@mixin gradient($start: #000000, $stop: #FFFFFF) {\r\n  background : ($start + $stop)/2;\r\n  background : -webkit-gradient(linear, left top, left bottom, color-stop(0, $start), color-stop(1, $stop));\r\n  background : -moz-linear-gradient(center top, $start 0%, $stop 100%);\r\n  background : -ms-linear-gradient(top, $start, $stop);\r\n  filter     : unquote(\"progid:DXImageTransform.Microsoft.gradient(startColorstr='#{$start}', endColorstr='#{$stop}', GradientType=0)\");\r\n}\r\n","// Font=================================================================================================\n$font: Tahoma, Arial, \"Microsoft YaHei\", sans-serif !default;\n$western-font: Georgia, Cambria, \"Times New Roman\", Times, serif !default;\n\n$font-size: 14px !default;\n$small-font-size: 12px !default;\n$h1-size: 24px !default;\n$h2-size: 20px !default;\n$h3-size: 18px !default;\n$h4-size: 16px !default;\n\n// Color================================================================================================\n$text-color: #979798 !default;\n$text-dark-color: #323232 !default;\n$body-color: #f5f5f5 !default;\n\n$white: #fff;\n$red: #eb6165;\n$gray: #fbfaf9;\n$dark-gray: #f7f6f6;\n//other=================================================================================================\n$content-width: 1200px;\n\n// Mixin================================================================================================\n@mixin inline-block($alignment: middle) {\n  display: inline-block;\n  @if $alignment and $alignment != none {\n    vertical-align: $alignment;\n  }\n  zoom: 1;\n  * + html & {\n    display: inline;\n  }\n}\n","body {\n  line-height: 1.5;\n  font-size: $font-size;\n  font-family: $font;\n  color: $text-color; }\n.content {\n  width: 1200px;\n  margin: 0 auto; }\na {\n  text-decoration: none; }\nli {\n  list-style: none; }\n","","",".page-index{\n  h1 {\n    color: red;\n  }\n}\n"],"mappings":"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","names":[],"sourceRoot":"/source/"} */ 202 | -------------------------------------------------------------------------------- /public/js/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Created by moqiao on 2016/7/19. 3 | */ 4 | window.onload = function(){ 5 | getData('/loansss') 6 | getData('/psddn') 7 | console.log('你早就该拒绝我') 8 | console.log('你早就该拒绝我') 9 | } 10 | 11 | function getData(url){ 12 | var xhr = new XMLHttpRequest 13 | xhr.responseType = 'json' 14 | xhr.onreadystatechange = function(){ 15 | if(this.readyState !== 4){ 16 | return 17 | } 18 | if(this.status === 200) { 19 | console.log(this.response) 20 | }else{ 21 | console.error(this.status) 22 | } 23 | } 24 | xhr.open('GET',url) 25 | xhr.send() 26 | } 27 | -------------------------------------------------------------------------------- /sass/_config.scss: -------------------------------------------------------------------------------- 1 | // Font================================================================================================= 2 | $font: Tahoma, Arial, "Microsoft YaHei", sans-serif !default; 3 | $western-font: Georgia, Cambria, "Times New Roman", Times, serif !default; 4 | 5 | $font-size: 14px !default; 6 | $small-font-size: 12px !default; 7 | $h1-size: 24px !default; 8 | $h2-size: 20px !default; 9 | $h3-size: 18px !default; 10 | $h4-size: 16px !default; 11 | 12 | // Color================================================================================================ 13 | $text-color: #979798 !default; 14 | $text-dark-color: #323232 !default; 15 | $body-color: #f5f5f5 !default; 16 | 17 | $white: #fff; 18 | $red: #eb6165; 19 | $gray: #fbfaf9; 20 | $dark-gray: #f7f6f6; 21 | //other================================================================================================= 22 | $content-width: 1200px; 23 | 24 | // Mixin================================================================================================ 25 | @mixin inline-block($alignment: middle) { 26 | display: inline-block; 27 | @if $alignment and $alignment != none { 28 | vertical-align: $alignment; 29 | } 30 | zoom: 1; 31 | * + html & { 32 | display: inline; 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /sass/_global.sass: -------------------------------------------------------------------------------- 1 | body 2 | line-height: 1.5 3 | font-size: $font-size 4 | font-family: $font 5 | color: $text-color 6 | .content 7 | width: 1200px 8 | margin: 0 auto 9 | a 10 | text-decoration: none 11 | li 12 | list-style: none 13 | -------------------------------------------------------------------------------- /sass/_mixins.scss: -------------------------------------------------------------------------------- 1 | @mixin size($w, $h) { 2 | width: $w; 3 | height: $h; 4 | } 5 | 6 | @mixin image-url($path) { 7 | background-image: url('./images/#{$path}'); 8 | } 9 | 10 | @mixin clearfix { 11 | &:after { 12 | content: ""; 13 | display: table; 14 | clear: both; 15 | } 16 | *zoom: 1; 17 | } 18 | 19 | @mixin float($direction) { 20 | float: $direction; 21 | *display: inline; 22 | } 23 | 24 | @mixin opacity($opacity) { 25 | filter: unquote("progid:DXImageTransform.Microsoft.Alpha(Opacity=#{round($opacity * 100)})"); 26 | opacity: $opacity; 27 | } 28 | 29 | // Make an element completely transparent. 30 | @mixin transparent { @include opacity(0); } 31 | 32 | @mixin text-overflow { 33 | max-width : 100%; 34 | overflow : hidden; 35 | text-overflow : ellipsis; 36 | white-space : nowrap; 37 | } 38 | 39 | @mixin word-break { 40 | word-break : break-all; 41 | word-wrap : break-word; 42 | white-space : normal; 43 | } 44 | 45 | @mixin border-radius($radius) { 46 | -webkit-border-radius : $radius; 47 | -moz-border-radius : $radius; 48 | border-radius : $radius; 49 | } 50 | 51 | @mixin gradient($start: #000000, $stop: #FFFFFF) { 52 | background : ($start + $stop)/2; 53 | background : -webkit-gradient(linear, left top, left bottom, color-stop(0, $start), color-stop(1, $stop)); 54 | background : -moz-linear-gradient(center top, $start 0%, $stop 100%); 55 | background : -ms-linear-gradient(top, $start, $stop); 56 | filter : unquote("progid:DXImageTransform.Microsoft.gradient(startColorstr='#{$start}', endColorstr='#{$stop}', GradientType=0)"); 57 | } 58 | -------------------------------------------------------------------------------- /sass/includes/_footer.scss: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kisnows/Express-Gulp-BrowserSync/b248c10f2f0c1a9d757de0fb1657c462a30434e4/sass/includes/_footer.scss -------------------------------------------------------------------------------- /sass/includes/_header.scss: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kisnows/Express-Gulp-BrowserSync/b248c10f2f0c1a9d757de0fb1657c462a30434e4/sass/includes/_header.scss -------------------------------------------------------------------------------- /sass/main.scss: -------------------------------------------------------------------------------- 1 | @import 'mixins'; 2 | @import 'config'; 3 | 4 | @import 'global'; 5 | //includes 6 | @import 'includes/_header'; 7 | @import 'includes/_footer'; 8 | 9 | //pages 10 | @import 'pages/index'; 11 | -------------------------------------------------------------------------------- /sass/pages/index.scss: -------------------------------------------------------------------------------- 1 | .page-index{ 2 | h1 { 3 | color: red; 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /server.js: -------------------------------------------------------------------------------- 1 | const path = require('path') 2 | const url = require('url') 3 | const chalk = require('chalk') 4 | const request = require('request') 5 | const express = require('express') 6 | 7 | const config = require('./config') 8 | const app = express() 9 | const router = express.Router() 10 | 11 | var viewPath = path.join(__dirname, 'views');`` 12 | // view engine setup 13 | app.set('views', path.join(viewPath)); 14 | app.set('view engine', 'pug'); 15 | 16 | // 静态资源 17 | app.use(express.static(path.join(__dirname, 'public'))) 18 | 19 | app.use('/', router); 20 | 21 | app.use(function (err, req, res, next) { 22 | err.status = err.status || 500 23 | res.status(err.status) 24 | res.send(err.message) 25 | }) 26 | 27 | //mock 28 | if (process.env.NODE_ENV === 'development') { 29 | console.log(chalk.yellow('dev server')) 30 | require('./data')(router) 31 | } else if (process.env.NODE_ENV === 'api') { 32 | router.use('/', function (req, res, next) { 33 | console.log(chalk.yellow(req.method + ' ' + req.url)) 34 | console.log('http://' + process.env.REMOTE_API + req.url) 35 | if (req.method.toUpperCase() === 'GET') { 36 | request({ 37 | qs: req.body, 38 | method: req.method, 39 | url: 'http://' + process.env.REMOTE_API + req.url, 40 | headers: req.headers 41 | }).pipe(res); 42 | } else if (req.method.toUpperCase() === 'POST') { 43 | request({ 44 | form: req.body, 45 | method: req.method, 46 | url: 'http://' + process.env.REMOTE_API + req.url, 47 | headers: req.headers 48 | }).pipe(res); 49 | } 50 | }); 51 | } 52 | router.get('/', function(req, res, next) { 53 | res.render('index', { title: 'Express' }); 54 | }); 55 | // 静态路由 56 | // router.use('/', function (req, res) { 57 | // var filePath = req.path 58 | // if (/\.jade$/.test(filePath)) { 59 | // var fileName = filePath.replace(/(\/|\.jade)/g, '') 60 | // console.log(fileName) 61 | // res.render(fileName) 62 | // } 63 | // }) 64 | 65 | const port = config.port || 3000 66 | 67 | app.listen(port) 68 | -------------------------------------------------------------------------------- /views/error.pug: -------------------------------------------------------------------------------- 1 | extends layout/layout 2 | 3 | block content 4 | h1= message 5 | h2= error.status 6 | pre #{error.stack} 7 | -------------------------------------------------------------------------------- /views/includes/footer.pug: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kisnows/Express-Gulp-BrowserSync/b248c10f2f0c1a9d757de0fb1657c462a30434e4/views/includes/footer.pug -------------------------------------------------------------------------------- /views/includes/header.pug: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/kisnows/Express-Gulp-BrowserSync/b248c10f2f0c1a9d757de0fb1657c462a30434e4/views/includes/header.pug -------------------------------------------------------------------------------- /views/index.pug: -------------------------------------------------------------------------------- 1 | extends layout/layout 2 | 3 | block content 4 | div.page-index 5 | h1 Welcome 6 | ul 7 | li 你的微笑- 8 | li 是我最美的回忆 9 | li 啊 10 | -------------------------------------------------------------------------------- /views/layout/layout.pug: -------------------------------------------------------------------------------- 1 | doctype html 2 | html 3 | head 4 | title= title 5 | meta(http-equiv="X-UA-Compatible" content="IE=edge") 6 | link(rel='stylesheet', href='./css/main.css') 7 | body 8 | include ../includes/header 9 | block content 10 | include ../includes/footer 11 | script(src="./js/index.js") 12 | --------------------------------------------------------------------------------