必威-必威-欢迎您

必威,必威官网企业自成立以来,以策略先行,经营致胜,管理为本的商,业推广理念,一步一个脚印发展成为同类企业中经营范围最广,在行业内颇具影响力的企业。

   dir  必威查看当前目录,url编码处理以及对于

2019-09-16 11:59 来源:未知

在线调节和测量试验方案的思考与执行

2015/08/28 · HTML5 · 调试

原稿出处: 李靖(@Barret李靖)   

本文的主题绪想不在移动端调试上,移动端调试无非便是调养页面和调治工具之间存在分离,消除这种分离并成立连结就会消除移动端的调试难点。入眼阐述的是所见即所得的调节和测验模式下会遇到的阻挠。

当我们打开网页,发掘两个模块未有正确地渲染大概空白时,倘使调节台有报错,会一向依照报错定位到源码地点上马 debug;假使调节台未有报错,则会基于模块名只怕模块特征的三个值,通过全局搜索找到那么些模块的职责,然后在调节和测量试验工具中断点,单步调节和测量检验,找到问题所在,此时大家或然会如此做:

情形一:

小A同学展开调控台,发现断点调节和测验不佳写代码,于是将裁减的源码复制一份保存到地头,格式化,然后将线上财富通过代理工科具代理到当三步跳件。

情形二:

小B同学早早的为温馨配了一份本地开荒条件,于是他遇见标题现在,直接去源码中牢固错误地方,由于应用的是预管理语言,所以须求先打包编写翻译之后再在地方预览效果。

情形三:

小C同学的调治格局是小A和小B的汇总版本,将线上的能源代理到本地 build 目录文件,在 src 目录下修改之后编写翻译打包到 build,然后预览。

cmd命令:

   ./  当前目录

   ../ 上一级

   dir  查看当前目录

   ls  查看当前目录下文件

   windows 切换盘符 d:

   cls清屏

   cd +文件加名

nodejs第二章节

前言

前面八个圈里,今后工程化的前端已经是主流.种种前端工程化的本领数不清.webpack.grunt ,gulp等之类,应接不暇.

而再回放jsp当前的意况.当真正落后了前者圈太多.全部的支付情势,如故广春节前古板的公司级web开荒格局.大把的jsp标签.struts标签去落到实处页面.也难怪只可以做守旧集团后台网站.

本身事先职业的克利夫兰某厂商正是这么,用jsp标签包装了extjs的组件. 全部的html代码都写在java代码里.通过xml配置来布局页面.确实极大的进级了付出功能(全部的付出都在配xml和写一些宗旨的逻辑).可是蛋疼的正是,写完页面后,全部风格丑陋.顾客总是会让您改改页面.那个时候你一直的机件反而会成为你的硬伤,或者退换页面一丢丢搭架子清劲风格.将在大把的改java代码.

背后摆脱了这么的公司,笔者起始尝试更主流的须臾间web开拓格局.扬弃丑陋的ext,经历了纯jquery时期,慢慢过渡到这两天的angular/vue 的MVVM前端框架.越来越快的支出功能.和越来越大气美观的页面风格.已经变为大家那边开采的关键本领体系.后台java实现.弱化了后台业务.首要的相互页面都坐落了angular的调整层和service层来完毕.

必威 1

Paste_Image.png

当技术系统稳步完善后,效能难点也随之而来.以前的思想公司网址是不曾设想过js,css压缩,合併等等.今后思量的时候,选拔三个工程化的前端工具就根本. 应用讨论过webpack和百度的fis等能力后.笔者最终选项了gulp.首先因为gulp的流式编写方式非常清晰.其次,大家的开辟工具全是英特尔liJ IDEA ,作为世界上最佳用的java开采idea.居然在分界面上团结的援助gulp的职务实行.协助界面包车型地铁gulp task调节和测验刚开掘的时候作者打动哭了好吧?

必威 2

Paste_Image.png

必威 3

Paste_Image.png


办事中用到的一些插件,轻易做个memo
body-parser
express的中间件
bodyParser用于深入分析客商端央求的body中的内容,内部采取JSON编码管理,url编码管理以及对此文本的上传管理.

☞ 代理调节和测验的愤懑

而对此相比复杂的线上情形,代理也会境遇大多阻力,举例:

线上财富 combo

并发错误的剧本地址为  ,它对应着 a.js,b.js,c.js 几个本子文件,假如我们利用 Fiddler/Charles那样的经文代理工科具调节和测量检验代码,就不可能不给那么些工具编写插件,恐怕在轮换配置内部加一群判定可能正则,费用高,门槛高。

线上代码压缩

包装压缩,那是上线在此之前的必经流程。由于我们在包装的环节中并未有虚构为代码增添sourceMap,而线上此前对应 index-min.jsindex.js 也因为安全地方的原因给干掉了,那给我们调节和测验代码形成了巨大的不方便人民群众。

代码依赖比较多,拉替代码难点

多多时候,大家的页面正视了多个 asserts 资源,而那个能源各自布满在两个商旅里面,乃至散播在不相同的宣布平台上,为了能够在源码上清晰的调节和测量检验代码,大家不得不将富有的财富下载到本地,时期假设存在下载代码的权位难题,整个调节和测验进程就慢下来,那是十三分无法经得住的事体。譬如某系统创设的页面,页面上的模块都以以货仓为维度区分的,三个页面只怕对应了5-四二十个货仓,下载代码实为劳动。

最可怕的调和是,本地未有对应的测验情形、代理工科具又不满意我们的急需,然后就不得不, 编辑代码->打包压缩->提交代码->查看效果->编辑代码->... ,倘诺你的项目开辟是这种情势,请停下来,思虑调节和测验优化方案,正所谓磨刀不误砍柴工。

es6:

1.let/const

2.指标里的方法function能够轻巧

3.函数中的私下认可参数

4.template

5.箭头函数

6.进行操作符

7.解构赋值

8.Symbol

9.class 模拟类,但实质是依附原型的

10.for ...of

11.promise 解决回调金字塔.回调鬼世界

12.生成器函数,能够脱离函数

13.JS模块化

回调函数

一.gulp入门

gulp是前端开垦进程中对代码进行构建的工具,是自动化项目标构建利器;她不只可以对网址财富开展优化,並且在开荒进程中好些个种新的职责能够运用准确的工具自动完结;使用他,我们不仅可以够很喜欢的编撰代码,並且大大升高大家的工效。

设置和使用gulp.必要安装node环境.况且使用node的npm管制工具. 若无接触过前端知识.看见node和npm确实挺懵逼的. 其实不然,对于三个java老手来说.npm你就大致的接头成maven就可以.其实是前端圈里形成的一个类maven的旅社,npm提供各样node插件的下载.命令也很轻松. npm init 就仿佛于mvn:eclipse 项目下会生成package.json文件,类似于pom.xml
请自学教程.
再自行设置gulp.传送门如下.
gulp详细入门.node,npm和gulp安装.
急需注意的是.npm安装插件分为全局安装和一些安装.全局安装指安装好的零件集会场全数工程通用.而有的安装只对当前工程应用. 而gulp不但供给全局安装,相同的时候须求对脚下项目部分安装.不然不能够平常使用.
在根目录增加一个gulpfile.js 即gulp的职务脚本文件.
在指令行输入 gulp 任务名 就能够执行脚本里对应任务名的义务.
<pre>

以下是职务代码轨范

var gulp = require('gulp')
var concat = require('gulp-concat');//合併组件

var uglify=require('gulp-uglify');//压缩组件

var clean = require('gulp-clean');//清空文件夹组件

var replace = require('gulp-replace');

var cheerio = require('gulp-cheerio');//dom操作组件

gulp.task('testConcat', function () {

gulp.src('dist/js')
    .pipe(clean());
gulp.src('js/*.js')
    .pipe(concat('all.min.js'))//合并后的文件名
.pipe(gulp.dest('dist/js'));

});

</pre>

gulp
gulp是前端开垦进度中对代码举办创设的工具,是自动化项目标塑造利器;她不只能对网址能源开展优化,并且在开拓进度中许多再次的职分能够利用科学的工具自动完结;使用她,大家不只好够很欢快的编排代码,而且大大升高我们的工效。
gulp是依据Nodejs的活动使时局维器, 她能自动化地成功 javascript/coffee/sass/less/html/image/css 等公事的的测量检验、检查、合併、压缩、格式化、浏览器自动刷新、安顿文件生成,并监听文件在转移后再一次钦命的这么些步骤。在实现上,她借鉴了Unix操作系统的管道(pipe)观念,前一级的输出,直接成为后超级的输入,使得在操作上特别简单。通过本文,大家将学习怎么着使用Gulp来更动开垦流程,进而使开垦非常便捷高效。
gulp 和 grunt 极其类似,但对待于 grunt 的再三 IO 操作,gulp 的流操作,能越来越快地更简便易行地成功创设筑工程作。
gulp.task(name, fn)那些你应经见过了
gulp.run(tasks...)尽只怕多的竞相运维七个task
gulp.watch(glob, fn)当glob内容发生转移时,试行fn
gulp.src(glob)再次回到三个可读的stream
gulp.dest(glob)再次回到二个可写的stream

☞ 开启懒人调节和测量检验形式

当见到线上边世难题(可能是其余同学负担页面包车型客车主题材料),脑中浮出如此的现象:

复制代码 我:"嘿,线上有毛病呀!笔者要调整代码!" Computer:"好的,主人。请问是哪个页面?"(弹出浮层) 小编:浮层中输入URAV4L。 Computer:"请问是哪些地点出标题了?" 作者:(指着计算机)"模块A和模块B。" Computer:正在下载A、B能源...正在将上线A、B映射到地点...自动打开A、B对应文件夹 笔者:编辑代码,然后实时预览效果。

1
2
3
4
5
6
7
8
复制代码
  我:"嘿,线上有问题啦!我要调试代码!"
电脑:"好的,主人。请问是哪个页面?"(弹出浮层)
  我:浮层中输入URL。
电脑:"请问是哪个地方出问题了?"
  我:(指着电脑)"模块A和模块B。"
电脑:正在下载A、B资源...正在将上线A、B映射到本地...自动打开A、B对应文件夹
  我:编辑代码,然后实时预览效果。

在此间大家需求化解这样多少个难点

  • 将页面前遭受应的持有仓库/资源罗列在客户眼下
  • 下载财富的权限提醒和权限管理
  • 线上财富解 combo,然后映射到地点

理所必然调节和测量试验之后,能够还会有三个操作:

本人:"哈,已经修复了,帮小编付出代码~" 计算机:正在diff代码...收到确认提交数字信号,提交到预发意况...收到已经预览能量信号...正在公布代码...收到线上回归复信号...流程停止

1
2
我:"哈,已经修复了,帮我提交代码~"
电脑:正在diff代码...收到确认提交信号,提交到预发环境...收到已经预览信号...正在发布代码...收到线上回归信号...流程结束

而外 debug 代码,大家须求做的就只是用眼睛看作用是否ok,整个工艺流程优化下来,体验是非常赞的!

NodeJS:

1.node.js支出条件搭建

2.npm nodejs包管理器

3.CommonJS模块化标准化,AMD(require)

4.导出模块/加载模块

Node.js 异步编制程序的直白反映正是回调

二,日常使用场景和gulp插件

从地点的代码轨范可以看到.gulp的天职在一发端供给引进精彩纷呈的插件.其实gulp本人只是提供了一种对文本管理的平台.
读入多个可能一堆文件.调用差别的插件串式的对文件实行一步步的处理.最后输出到taregt目录.
一体化跟java的流管理没什么大的不一致.输入文件.最后写入等等.
<pre>
gulp.src('js/*.js') //读取统配命令命中的全数文件
.pipe(concat('all.min.js'))//地阿偶concat插件对输入流合併管理,方法的参数是联合后的新文件名
.pipe(gulp.dest('dist/js'));//把流输出到dist/js目录下
</pre>

日常最项目上其实用的情况大约是如此的:
应用angular实行付出,angular的service.js,controller.js,filter.js各是二个文件.文件都尚未压缩.源文件jsp上有八个<script>引进文件.
而付出截止后.基于网页优化要做的便是:

  1. 为了减弱http乞求,把多少个js合併成三个js,
  2. 为了收缩js诉求的加载时间,把合併后的js压缩成贰个min.js
  3. 本来的多个js已经济体改为了三个js.需求把出口的jsp文件里的多个<script>去掉.换来援引新的min.js

所选择到的插件分别是

  • gulp-concat 文件合併插件
  • gulp-uglify 文件降低插件
  • gulp-cheerio dom操作修改dom插件
    <pre>
    源文件:
    <%@ page contentType="text/html;charset=UTF-8" language="java" %>
    <!DOCTYPE html>
    <html>
    <head>
    <title>Hello, World</title>
    <jsp:include page="/WEB-INF/jsp/include/jquery.jsp"></jsp:include>
    <script src="js/angular.js"> </script>
    <script src="js/service.js"> </script>
    <script src="js/controller.js"> </script>
    <script src="js/filter.js"> </script>
    </head>
    <body>
    <%=aa%>
    </html>
    </pre>

<pre>
期望结果:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!DOCTYPE html>
<html>
<head>
<title>Hello, World</title>
<jsp:include page="/WEB-INF/jsp/include/jquery.jsp"></jsp:include>
<script src="js/all.min.js"></script></body>
</head>
<body>
<%=aa%>
</html>
</pre>

对此,大家修改gulpfile.js.写上团结的统一压缩替换义务代码
<pre>

var gulp = require('gulp');

var concat = require('gulp-concat');//合併组件

var uglify=require('gulp-uglify');//压缩组件

var cheerio = require('gulp-cheerio');//dom操作组件

gulp.task('testConcat', function () { // testConcat正是职务名 在命令行实施gulp testConcat就能够实行此任务
// 职责第一步,对js文件进行拍卖
gulp.src('js/*.js') //加载全体的js
.pipe(concat('all.min.js'))//调用联合组件方法concat(),合併那一个js.并起二个新的称呼
//职责第二步,对联合的公文举行压缩
.pipe(uglify()) //调用压缩组件方法uglify()
.pipe(gulp.dest('dist/js')); //输出到目的目录

//职务第三步,对jsp文件实行管理.
gulp.src('index.jsp') //加载源jsp.
.pipe(cheerio(function ($) { //调用cheerio插件实行dom操作
$('script').remove(); //cheerio类似于jquery dom操作. 通过jq操作移除原节点,append新节点
$('head').append('<script src="js/all.min.js"></script>');

  }))

.pipe(gulp.dest('dist'));

});

</pre>
命令行,只怕idea运维 gulp的任务.就能够获取结果

必威 4

Paste_Image.png

此处有多少个坑.,能观察运营结果并非我们盼望的全部的jsp. 页面包车型客车jsp标签乱掉了.
那是因为cheerio 插件他在做dom操作的时候,首先供给把源文件html实行智能补全管理,会把未终止的竹签补齐.他本人是操作html的.并不协理jsp的dom操作.
道理当然是那样的,我们也会有管理的办法.稍微调度一下任务代码.在调用cheerio 此前,先把jsp标签的<% 和%>替换掉. 那样cheerio 会感到他们是家常便饭的字符串.等cheerio 管理终结后,我们在轮换回来.
<pre>
gulp.task('testConcat2', function () {

  gulp.src('js/*.js')
    .pipe(concat('all.min.js'))//合并后的文件名
    .pipe(uglify())
    .pipe(gulp.dest('dist/js'));

  gulp.src('index.jsp')
     .pipe(replace("<%","~%")) //替换掉jsp标签的<%
     .pipe(replace("%>","%~"))//替换掉jsp标签的<%
     .pipe(cheerio(function ($) {
        $('script').remove();
                $('head').append('<script src="js/all.min.js"></script>');

     }))
     .pipe(replace("%~","%>")) //替换回来jsp标签的<%
     .pipe(replace("~%","<%"))//替换回来jsp标签的<%
    .pipe(gulp.dest('dist'));

});
</pre>

如此,八个粗略的jsp上台景就用gulp做了滑坡优化管理了.最后结果

必威 5

Paste_Image.png

必威 6

Paste_Image.png

本来gulp还会有许多任何插件,举个例子压缩html内容.混淆压缩js等等.遵照气象选拔

// 载入外挂
var gulp = require('gulp'),
browserify = require('browserify'),//这里用不上,管理js依赖的
source = require('vinyl-source-stream'),//一样这里用不上,和上边10%同的
uglify = require('gulp-uglify'),//使用gulp-uglify压缩javascript文件,减小文件大小。
clean = require('gulp-clean'),//清理文件
notify = require('gulp-notify'),//加调控台文字描述用的
buffer = require('vinyl-buffer'),
less = require('gulp-less'),//转换less用的
autoprefixer = require('gulp-autoprefixer'),//扩展个人变量前缀
minifycss = require('gulp-minify-css'),//压缩
concat = require('gulp-concat'),//合并
fileinclude = require('gulp-file-include'),// include 文件用
template = require('gulp-template'),//替换变量以及动态html用
rename = require('gulp-rename'),//重命名
webserver = require('gulp-webserver'),//三个归纳的server,用python的SimpleHttpServer会锁文件夹
imagemin = require('gulp-imagemin'),//图片压缩
gulpif = require('gulp-if'),//if判别,用来差别生产景况依然支付条件的
rev = require('gulp-rev'),//加MD5后缀
revReplace = require('gulp-rev-replace'),//替换援引的加了md5后缀的文件名,修改过,用来加cdn前缀
addsrc = require('gulp-add-src'),//pipeline中途添Gavin件夹,这里未有使用
del = require('del'),//也是个删除···
vinylPaths = require('vinyl-paths'),//操作pipe中文件路线的,加md5的时候利用了
runSequence = require('run-sequence');//控制task顺序 Runs a sequence of gulp tasks in the specified order

☞ 消除代理境遇的主题材料

上边大家关系了多少个难点,通常开垦境遇最头痛的四个是 combo ,曾经大家页面上的代码加多少个?_xxx  参数就可以一贯最早调节和测量试验形式,那是因为程序的进口独有一个,何况具备脚本的依附也卷入到贰个叫做 deps.js  文件中,加上调节和测验参数之后,可以将原本combo 加载的文本:  ,遵照非 combo 的方法加载:

1
2
3
http://example.com/path/a.js
http://example.com/path/b.js
http://example.com/path/c.js

地方的代码能够轻易地代理到地头,不过有的系统生成的代码并未 deps.js  文件,它是将脚本直接出口到页面上:

<script src=";

1
<script src="http://example.com/path/??a-min.js,b-min.js,c-min.js"></script>

☞ 解决 combo 问题

那儿透过 Fiddler/Charles工具相比难满意急需,对于那么些主题素材有三个管理方案:

1). 浏览器乞求全体代理到地头的二个服务

率先写贰个本地服务:

JavaScript

var http = require('http'); // npm i http-proxy --save var httpProxy = require('http-proxy'); var proxy = httpProxy.createProxyServer({}); var server = http.createServer(function(req, res) { console.log(req.url); if(req.url.indexOf("??") > -1){ // combo财富让 3400 端口的劳务管理proxy.web(req, res, { target: '' }); } else { // 直接重回 proxy.web(req, res, { target: req.url }); } }).listen(3399, function(){ console.log("在端口 3399 监听浏览器必要"); });

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var http = require('http');
// npm i http-proxy --save
var httpProxy = require('http-proxy');
var proxy = httpProxy.createProxyServer({});
 
var server = http.createServer(function(req, res) {
  console.log(req.url);
  if(req.url.indexOf("??") > -1){
    // combo资源让 3400 端口的服务处理
    proxy.web(req, res, { target: 'http://127.0.0.1:3400' });
  } else {
    // 直接返回
    proxy.web(req, res, { target: req.url });
  }
}).listen(3399, function(){
    console.log("在端口 3399 监听浏览器请求");
});

代码的野趣是,利用 http-proxy 那些 npm 包,代理浏览器的呼吁,浏览器上行使 switchSharp 设置本地代理为  ,当呼吁过来,先决断url,假设 url 中蕴藏了 ?? 则将其用作 combo 能源管理,代理给地点的另八个服务  ,这几个服务抽出诉求后会将 combo 内容分解成多少个,全体央浼完以往再吐出来。

2). 使用本地服务伏乞 html 代码,替换 html 代码内容

应用强制花招(源码替换)将代码解 combo,比如源码页面为:

<!-- html code --> <script src="; <!-- html code -->

1
2
3
<!-- html code -->
<script src="http://example.com/path/??a-min.js,b-min.js,c-min.js"></script>
<!-- html code -->

运用本地服务央浼那么些url,然后转变来:

<!-- html code --> <script src="; <script src="; <script src="; <!-- html code -->

1
2
3
4
5
<!-- html code -->
<script src="http://example.com/path/a.js"></script>
<script src="http://example.com/path/b.js"></script>
<script src="http://example.com/path/c.js"></script>
<!-- html code -->

贯彻那个操作的代码:

JavaScript

var http = require('http'); // npm i request --save; var request = require('request'); http.createServer(function(req, res){ var path = req.url.slice(req.url.indexOf("path=") + 5); console.log(path); if(!path) { res.write("path is empty"); res.end(); return; } request(path, function (error, response, body) { if (!error && response.statusCode == 200) { console.log(body); // 代码替换 body = body.replace('<script src=";', '<script src=" <script src=" <script src=";' ); res.write(body); res.end(); } }); }).listen(3399, function(){ console.log("listening on port 3399"); });

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
var http = require('http');
// npm i request --save;
var request = require('request');
http.createServer(function(req, res){
    var path = req.url.slice(req.url.indexOf("path=") + 5);
    console.log(path);
    if(!path) {
        res.write("path is empty");
        res.end();
        return;
    }
    request(path, function (error, response, body) {
        if (!error && response.statusCode == 200) {
            console.log(body);
            // 代码替换
            body = body.replace('<script src="http://example.com/path/??a-min.js,b-min.js,c-min.js"></script>',
                '<script src="http://example.com/path/a.js"></script>
                <script src="http://example.com/path/b.js"></script>
                <script src="http://example.com/path/c.js"></script>'
            );
            res.write(body);
            res.end();
        }
    });
}).listen(3399, function(){
    console.log("listening on port 3399");
});

比方诉求  ,就能够获得天猫首页的源码,然后对获得的代码做替换。

☞ 化解代码压缩难点

对于这么些难题,建议在线上放两份源码,一份是压缩源码,一份是未压缩源码,当页面 url 存在 debug 参数的时候,重临未压缩版本,符合规律再次来到压缩版本。当然,也足以选取上述情势管理难点。

可是,更合理的艺术应该是 sourceMap,前端未有地下,压缩代码只是增添了 黑客 的抨击花费,并不要紧碍有本领的 hacker借系统漏洞侵略。所以可认为源码提供一份 sourceMap 文件。

JavaScript

var gulp = require('gulp'); var sourcemaps = require('gulp-sourcemaps'); gulp.task('javascript', function() { gulp.src('src/**/*.js') .pipe(sourcemaps.init()) //.pipe(xx()) .pipe(sourcemaps.write()) .pipe(gulp.dest('dist')); });

1
2
3
4
5
6
7
8
9
10
var gulp = require('gulp');
var sourcemaps = require('gulp-sourcemaps');
 
gulp.task('javascript', function() {
  gulp.src('src/**/*.js')
    .pipe(sourcemaps.init())
      //.pipe(xx())
    .pipe(sourcemaps.write())
    .pipe(gulp.dest('dist'));
});

至于 sourceMap 的 gulp 插件配置,详细情况能够戳这里。不止是 JavaScript,CSS 也许有 source maps,这么些消息方可在 Chrome 调控台的装置选项中看到:

必威 7

☞ 代码的拉取

万一一个类型唯有你领会什么修改,那那几个类别的技能陈设就有一些不好了,为了让大家都能管理你项目中的难点,绝对要索要二个精简的形式为开垦者火速搭建测量检验景况,文书档案是一方面,假如有个一键操作的命令,那就更棒了!

# 运营脚本 start: createFile getMod getPage # 创设目录 createFile: @[ -d module ] || mkdir module @[ -d page ] || mkdir page # 拉取模块旅馆,这里有几12个,比较费时,请耐心等待... getMod: cd module; for i in $(MODS); do [ -d $(MODPATH)$$i ] || git clone $(MODPATH)$$i; git co -b master; git co -b $(MODSV); done # 拉取页面仓库,tbindex getPage: cd page; @[ -d tbindex ] || git clone $(PAGEPATH)$PAGE;

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# 启动脚本
start: createFile getMod getPage
 
# 创建目录
createFile:
  @[ -d module ] || mkdir module
  @[ -d page ] || mkdir page
 
# 拉取模块仓库,这里有几十个,比较费时,请耐心等待...
getMod:
  cd module;
  for i in $(MODS); do
    [ -d $(MODPATH)$$i ] || git clone $(MODPATH)$$i;
    git co -b master;
    git co -b $(MODSV);
  done
 
# 拉取页面仓库,tbindex
getPage:
  cd page;
  @[ -d tbindex ] || git clone $(PAGEPATH)$PAGE;

 

上边是一个 MakeFile 的有的代码,功用是创建开采目录,拉取分支音信,然后开首服务器,打开浏览器,使用 IDE 张开目录,万事就绪,只等主人敲代码。

全体育工作艺流程就一两分钟,实现开拓以前全体的希图职业。这些剧本不止是给本身行使,要是别的人也亟需到场开荒,贰个限令就会让参加者步向开垦形式,加上文书档案表明,省却了非常多关系开销。

fs模块(读写文件)

var fs = require("fs");//加载模块

//异步读取文件

fs.readFile("./readme.txt","utf8", (err, data) => {

if(err) throw err;

console.log(data);

});

//同步读取文件 Synchrous

var data = fs.readFileSync("./readme.txt","utf8");

console.log(data);

//异步写入文件

fs.writeFile("./test.txt", "This is test content~~~",(err) => {

if(err)throw err;

console.log("写入成功");

})

console.log("write");

//同步写入文件

fs.writeFileSync("./test.txt", "This is test content~~~");

console.log("write");

翻看路线音讯stat:fs.stat(path, (err, stat) => {})

fs.stat("./test", (err, stat) => {

if(err) throw err;

console.log(stat);

if(stat.isFile()) {

console.log("该路径为文件");

}else if (stat.isDirectory()) {

console.log("该路径为文件夹");

}

})

异步编制程序依托于回调来兑现

八个简易的例子
var gulpif = require('gulp-if');
var uglify = require('gulp-uglify');

☞ 在线调节和测验实施(贰个系统的调治工具)

输入要求调剂的页面U兰德路虎极光L(如 http://www.taobao.com):

必威 8

插件会剖析 DOM,遍历得到页面全数被引述到的库房:

必威 9

选用必要调治将养的模块(颗粒度细分到了html/js/css),点击调节和测量检验按键,能够见到调节和测量检验页面包车型大巴财富都会援用当地下载的公文。

path模块

var path = require("path"); //加载模块

path.dirname(url) 获取目录名

path.extname(url)获取后缀名

path.join([...paths]) 拼接路线

var url = "";

var p1 = path.basename(url,".html");

console.log(p1); //path

var p2 = path.dirname(url);

console.log(p2); //

var p3 = path.extname(url);

console.log(p3); //.html

var p4 = path.join(__dirname, "./a", "../b", "c");

console.log(p4); //E:nodenodejs_2bc

事例1:http服务器回调

var condition = true; // TODO: add business logic

☞ 小结

优化流程、优化架构是大家拼命百折不回的取向,本文首要演讲,编辑代码到调节和测验线上效益的长河,提议了解决combo 和代码压缩等难点的方案和建议。希望可以给不专长代理调节和测量试验的同窗一点启迪。

1 赞 收藏 评论

必威 10

querystring模块 查询字符串

var qs = require("querystring");

var o = {

color: "red",

border: "1px solid red",

"font-size": "16px"

}

var ret = qs.stringify(o, ";", ":");

console.log(ret);

// "color:red;border: 1px solid red;font-size: 16px"

  • var http = require(“http”);//引进二个http的模块

    var server = http.createServer(function (req,res) {

        //向前台响应内容(数据)
        res.end(“大家好,我是yuk”);
    });
    //listen(端口,域名,成功的回调)
    server.listen(8080,”localhost”, function () {
        console.log(“服务器运转成功!”);
    });

gulp.task('task', function() {
gulp.src('./src/*.js')
.pipe(gulpif(condition, uglify()))
.pipe(gulp.dest('./dist/'));
});

http模块

var http = require("http"); //加载模块

var server = http.createServer((request, response) => {

//创立四个web服务器

//request

//response

//设置响应头

console.log(request.url);

switch(request.url) {

             case "/":

                    response.write("首页");

                     break;

case "/list":

response.write("列表页");

break;

case "/detail":

response.write("详情页");

break;

}

response.writeHead(200, {

"Content-Type":"text/html; charset=utf8"

})

response.end();

//if(request.url)

})

//http80端口号 ftp23端口号

server.listen(3000, function() {

console.log("server has started at port 3000");

})

事例2:读取文件操作

 

1.http呼吁页面,不是该文件目录下的页面重定向,其他的基于目录查找

var http = require("http"); //CommonJS标准 加载模块

var fs = require("fs");

var path = require("path");

var server = http.Server(); //创造服务器

server.on("request", function(req, res) {

var filepath = path.join(__dirname, "./www", req.url);

if(req.url === "/") {

filepath = path.join(filepath, "index/html");

}

try{

var stat = fs.statSync(filepath);

if(stat.isFile()) {

var content = fs.readFileSync(filepath);

res.setHeader("Content0length", Buffer.bytelength(content))

res.write(content);

}else if(stat.isDirectory() {

//当央浼的门路是目录的时候

})

}catch(e) {

//重定向301(永久) 302(暂时)

res.writeHead(302, {

"Location" : "/"

})

}

res.end();

})

server.listen(3000, function() {

console.log("server has started");

})

  • var fs = require(“fs”);//文件模块

    //异步的措施->当文件读取达成后推行回调函数内容,不影响其它后续程序的实践
    /*var data = fs.readFile(“1.txt”,”utf8”, function (err,data) {

        console.log(“读取文件成功”);
        console.log(data);
    });*/
    //同步获取文件的主意->必得读取完结未来再进行之后的顺序
    var data = fs.readFileSync(“1.txt”,”utf8”);
    console.log(data);
    console.log(“我是其余的代码”);

express

serve-favicon
Node.js middleware for serving a favicon.
Examples

Typically this middleware will come very early in your stack (maybe even first) to avoid processing any other middleware if we already know the request is for /favicon.ico.

express

var express = require('express')
var favicon = require('serve-favicon')
var path = require('path')

var app = express()
app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')))

// Add your routes here, etc.

app.listen(3000)


morgan
morgan是express暗中认可的日志中间件,也足以脱离express,作为node.js的日记组件单独使用
var express = require('express');
var app = express();
var morgan = require('morgan');

app.use(morgan('short'));
app.use(function(req, res, next){
res.send('ok');
});

app.listen(3000);
ode basic.js运营程序,并在浏览器里拜见 ,打字与印刷日志如下

➜ 2016.12.11-advanced-morgan git:(master) ✗ node basic.js
::ffff:127.0.0.1 - GET / HTTP/1.1 304 - - 3.019 ms
::ffff:127.0.0.1 - GET /favicon.ico HTTP/1.1 200 2 - 0.984 ms


express 的 模板引擎
jade 和 ejs

jade
index.jade
doctype
html
head
title hello
body
h1 hello world

随着在命令行施行 jade -P index.jade ,编写翻译后的文书 index.html 内容如下:
<!DOCTYPE html>
<html>
<head>
<title>hello</title>
</head>
<body>
<h1>hello world</h1>
</body>
</html>

ejs
特性

<% %> 用于调节流

<%= %> 用于转义的输出

<%- %> 用于非转义的输出

 


handlebars
模板引擎
在模板中运用{{ }}或{{{ }}}的地点就是象征
{{ }} 会转译标签
{{{ }}} 则直接沟通

const productTemplateContent = fs.readFileSync(path.join(__dirname, '../templates/product.xml.hbs'), 'utf-8');
const productTemplate = handlebars.compile(productTemplateContent);
let html = productTemplate({ product: product, productJson: (new Buffer(JSON.stringify(product))).toString('base64') });

 


crypto
node自带模块.这些模块的首要意义是加密解密。
var md5 = crypto.createHash(‘md5’);
var sha1 = crypto.createHash('sha1');

 


needle
Nimble, streamable HTTP client for Node.js. With proxy, iconv, cookie, deflate & multipart support.
轻量级的http client模块,集成了iconv-lite,跟request类似
var needle = require('needle');

needle.get('', function(error, response) {
if (!error && response.statusCode == 200)
console.log(response.body);
});

Callbacks not floating your boat? Needle got your back.

var data = {
file: '/home/johnlennon/walrus.png',
content_type: 'image/png'
};

needle
.post('', data, { multipart: true })
.on('readable', function() { /* eat your chunks */ })
.on('done', function() {
console.log('Ready-o, friend-o.');
})

needle.post(url, data, requestOptions, function(err, resp, body) {
let data;
if (body) {
let bodyText = body.toString('utf-8');
try {
data = JSON.parse(bodyText);
} catch (e) {
data = bodyText;
}
}
mainCallBack(err, body);
});


superagent
superagent是nodejs里贰个特别有助于的客商端央求代理模块,当你想管理get,post,put,delete,head央浼时,你就应有想起该用它了:)

superagent 是三个轻量的,渐进式的ajax api,可读性好,学习曲线低,内部正视nodejs原生的呼吁api,适用于nodejs遭逢下.

四个回顾的post央浼,并安装诉求头音讯的事例

request
.post('/api/pet')
.send({ name: 'Manny', species: 'cat' })
.set('X-API-Key', 'foobar')
.set('Accept', 'application/json')
.end(function(res){
if (res.ok) {
alert('yay got ' + JSON.stringify(res.body));
} else {
alert('Oh no! error ' + res.text);
}
});

SuperAgent伏乞的暗许方法为GET,所以你可能够简单地写如下代码:

request('/search', function(res){

});



 

http协议:

HyperText Transport Protocol)是超文本传输合同的缩写.

http央求:get/post/put/delete(get在地址栏,传输速度快,大小有限制.在头,只好传输一些文本;post加密传输,在正文)

能够倡导http乞请的艺术:浏览器/postman/curl/Fiddle/php/node.js

http1.0和http1.1的差距:1.0是每回需要都创设贰个连接,而1.1是多个央浼一个连接.

报文:请求头(post有content-type:"application-x-www-form-urlencoded", cookie)+正文

xhr.readystate

XMLHttpRequest.UNSENT  0        初叶化连接

XMLHttpRequest.OPENED  1        连接创设

XMLHttpRequest.HEADER_RECEIVED 2  接收到伏乞头

XMLHttpRequest.LOADING  3        管理数量

XMLHttpRequest.DONE    4        管理完毕

xhr.status HTTP响应状态码

1上马  101 切换公约

2开头  成功  200

3开头  重定向  304 301/302

4方始  客商端错误  404 403

5初步  服务器端错误

常用模块教学

2.爬虫 cheerio

原理: 1.拉取页面(字符串)http.get/request(node),file_get_content(php)

2.利用模块,方便快捷筛选.cheerio(node), simple.html.dom.php(php)

3.募集音讯

npm install cheerio //安装cheerio模块

npm init

// spider.js

var http    = require("http");

var cheerio = require("cheerio");

var fs      = require("fs");

util

3.express 基于 Node.js 平台,急迅、开放、极简的 web 开拓框架。

nmp install express -g

npm install express-generator -g(快速创设express的完好目录)

express -h

express myapp

cd myapp

npm start

express

1.新建文件夹

cd到该文件目录下

npm init (enter name:myapp enter....)

npm install express

在myapp里面新建app.js

在app.js里面写代码

var express  = require("express"),//加载express模块

http = require("http"), //加载http模块

app  = express(), //创立二个express实例

server  = http.createServer(app); //app能够看成http创建服务器的回调函数

//静态财富挂载,设置静态财富目录

//中间件 express.static

//挂载中间件 使用use

app.use(express.static("public"));

//定义二个得到访谈客户IP的中间件

//哪个先挂载,先利用哪个的代码

var ips = [];

function getIp(req, res, next) {

console.log(req.ip);

ips.push(req.ip);

next();

}

function responseIP (req, res, next) {

res.send(req.ip);

}

app.use((req, res, next) => {

console.log("hello");

next();

})

app.use(getIp);

app.use(responseIP);

app.get("/", (req, res) => {

res.send("首页");

})

app.get("/list", (req, res) => {

// console.log(req.ip);获取ip

res.send("列表页");

})

app.get("/details", (req, res) => {

res.send("详情页");

})

server.listen(3000, function() {

//监听端口号3000,并提醒服务成功打开

console.log("Server has started");

})

总括express:中间件和路由.

兑现一而再

3.websocket 营造实时应用(你猜小编画,录制直播)

全双工、双向数据、长连接的协商,h5新添天性

劳务器端可以积极向浏览器端发送音信

非得浏览器要援助,服务器要援助,数据传输格式是Frame

进度:第一回是由客商端发起,必要的报文的央浼头会多一些内容,必要服务器退换左券.

劳务器端响应回报文,响应头也会多几条数据,之后就能够创制长的连接.

a. 发起呼吁,跟一般的http央浼例外的地点,

请求头 包括:

Sec-WebSocket-Key:asgK0L1sVa22xbiq8MU58w==

Sec-WebSocket-Version:13

Upgrade:websocket

让服务器更新切换左券 websocket

b. 服务器收到供给,upgrade

由此一定的手续算法 发生

Sec-WebSocket-Accept:IQcF4EGKE8sALj3PxJRvYQ1iG2Y

2.  npm init

npm install socketio express --save-dev

例子

socketio 是对websocket合计封装的贰个模块,让客商端和劳动器端的写法都以一律的

socket.emit()发数据

socket.on()收数据

监听顾客端连接,回调函数会传送此次连接的socket

io.on('connection',function(socket));

给具有客户端广播音信

io.sockets.emit('String',data);

给钦命的客商端发送消息

io.sockets.socket(socketid).emit('String', data);

监听客商端发送的新闻

socket.on('String',function(data));

给该socket的客商端发送信息

socket.emit('String', data);

3.WebSocket

new Websocket("ws:localhost/chat")

  • var util = require(“util”);
    //达成持续
    function Parent(){
        this.name = “老爸”;
        this.age = 50;
        this.sayHello = function (){

            console.log(‘hello’);
        }
    }
    Parent.prototype.showName = function (){

        console.log(this.name);
    }
    function Child(){
        //要承接函数内部的能够使用call只怕apply
        this.name = “儿子”;
    }
    //通过这种措施得以一而再父类原型中的方法和属性
    util.inherits(Child,Parent);
    var parentObj = new Parent();
    parentObj.showName();
    var childObj = new Child();
    childObj.showName();

gulp

npm init

npm install gulp --save-dev

新建 gulpfile.js(默许实践的文本)

//gulpfile.js

//1.配备义务, 2.活动实行

var gulp = require("gulp");

var uglify = require("gulp-uglify");

//task1 定义二个任务ufligy 压缩js

gulp.task("uglify" ,function() {

gulp.src("./src/js/*.js")

.pipe(uglify())

.pipe(gulp.dest("./dist/js"))

})

安装gulp-uglify插件 npm install gulp-uglify --save-dev

新建src文件夹 > js文件夹 >demo.js

新建dist文件夹> js文件夹 >

运行 gulp uglify

下一场在dist文件夹就能够找到已经减弱的demo.js

插件:gulp-less

插件:gulp-minify-css

//文件看守, 监听./src/less/*.less 文件的改换,变化运维该less任务

gulp.task("default", ["uglify", "less"], function() {

gulp.watch("./src/less/*.less", ["less"]);

})

//运营 gulp即可纵然改动代码

输出对象

webpack

全局安装webpack npm install webpack --save-dev

新建文件夹webpack

1.伊始化叁个门类 npm init

name:不能为webpack

2.在该文件夹上面设置npm install webpack --save-dev

  1. webpack 能源模块化

webpack ./app/main.js ./app/bundle.js

  1. mongodb 非关系型数据库

mongoose Nodejs操作mongodb数据库的模块

  • console.log(util.inspect(obj));

品种验证

  • console.log(util.isArray([]));//剖断是不是为三个数组
    console.log(util.isRegExp(/d/));//推断是还是不是为贰个正则表明式

event

事件概念

  • 事件
    * 又称作宣布订阅情势
    * 又叫做观望者情势
    * 当宗旨对象产生变化时,会打招呼全数的观看者对象,更新本人的走动

获得事件模块

  • var events = require(“events”).伊夫ntEmitter();//老的写法,跟上边的写法是等价的
    var events = require(“events”);

例子:

TAG标签:
版权声明:本文由必威发布于必威-前端,转载请注明出处:   dir  必威查看当前目录,url编码处理以及对于