在项目开发的过程当中,总会有前端开发快完成,后端接口却迟迟提供不了的情况。此时为了不影响前端开发的进度,我们可以借助puer来模拟后端接口测试。简单的说,puer就是一个可以实时刷新的前端服务器。具体关于puer的介绍可以参考这篇文章:http://leeluolee.github.io/2014/10/24/use-puer-helpus-developer-frontend/

1.先安装nodeJS

2.安装puer

npm install puer -g

3.puer命令介绍

Usage:   puer [options...]

Options:

-p,--port       server's listen port, 8000 default,可使用这个命令修改端口,比较常用

-f,--filetype   fileType to watch(split with '|'), default 'js|css|html|xhtml'

-d,--dir        your customer working dir. default current dir

-i,--inspect   start weinre server and debug all puer page

-x,--exclude   exclude file under watching(must be a regexp), default: ''

-a,--addon      your addon's path,绑定域名,比较常用

-t,--target     proxy url,代理URL,比较常用,默认是localhost

--no-reload           close  auto-reload feature,(not recommended)

--no-launch           close the auto launch feature

-h,--help       help list

4. 使用方法

4.1命令行中输入以下命令。(第一种方法),可使用这种方法快速编写静态页面,不需要手动刷新。

cd /path/to/workspace ↵

puer

puer会默认打开http://localhost:8000/(端口可以用 -p 8001参数进行控制),页面会列出该目录下所有的文件

4.2命令行中输入以下命令(第二种方法),这种方法可以实时更新接口数据。

cd /path/to/workspace ↵

puer -a route.js

puer提供了叫插件(addon)的功能,集成了express的route.js(route.js的名字可以随意取)来达到最简的路由配置,可以提供基于真实http请求与相应的动态的mock数据。route.js文件代码如下:

// use addon to mock http request
module.exports = {
// GET
"GET /v1/posts/:id": function(req, res, next){
// response json format
res.send({
title: "title changed",
content: "tow post hahahah",
desc:'aaaa',
age:'111',
name:'bbbb'
})
},
// PUT POST DELETE is the same
"PUT /v1/posts/:id": function(){ },
"POST /v1/posts": function(){ },
"DELETE /v1/posts/:id": function(){ }
}

它其实就是一段nodejs程序,输出是一配置对象,key的空格前代表的是请求Method,后半部分是请求路径,而value代表回调函数和express的路由中间件是一致的,传入的是request和response对象。返回配置中的URL就可以返回定义的值,如下图:

4.3.使用代理模式,应用puer到以有服务器中,这种方法最实用,工作中也是用到最多的。

一般在开发过程中,完全使用静态文件开发比较少,一般都是会启动本地的运行环境。这个时候,我们可以使用--target path(-t命令)切换到代理模式将puer作为一个代理服务器使用。比如本地已经存在一个localhost:7070的服务,你要在其上实现自动刷新的功能,请使用-t 或 --target。这样puer的服务器地址就会指向你本地服务(localhost:7070)的地址,可以配合addon模式使用,这样就可以直接使用定义的接口了。操作步骤如下图:

DOM命令中输入:

puer -t http://localhost:7070 -a a.js

-t http://localhost:7070   使用代理,代理指向localhost:7070,locahost:7070指工程本地启动的服务

-a a.js   页面所需的所有接口都写在a.js里面,配置路由,这样就可以提供基于真实http请求与相应的动态的mock数据

如果是在工程代码所在的目录下执行puer(比如上面的例子:D:\git\myProject),最大的好处是:

1.无论是写样式还是html代码,页面实时刷新。

2.模拟真实的http请求,自定义接口返回的数据。

如果是其他的目录,也可以模拟真实的http请求,只是不能随时监听工程目录下的文件变化。

使用代理服务后,页面的访问地址可以和接口文件里的请求地址处于一个域下的,所以发请求不会有跨域问题。

另外一种比较简单的调试方法就是,使用上述4.2的方法启动puer,JS里的请求数据写好,然后参考chrome设置--disable-web-security解决跨域这篇文章来启动chrome,即使在不同域下,也可以直接使用接口数据进行调试了。

puer工具的使用的更多相关文章

  1. 超简单工具puer——“低碳”的前后端分离开发

    本文由作者郑海波授权网易云社区发布. 前几天,跟一同事(MIHTool作者)讨教了一下开发调试工具.其实个人觉得相较于定制一个类似MIHTool的Hybrid App容器,基于长连的B/S架构的工具其 ...

  2. Unity3d入门 - 关于unity工具的熟悉

    上周由于工作内容较多,花在unity上学习的时间不多,但总归还是学习了一些东西,内容如下: .1 根据相关的教程在mac上安装了unity. .2 学习了unity的主要的工具分布和对应工具的相关的功 ...

  3. 细说前端自动化打包工具--webpack

    背景 记得2004年的时候,互联网开发就是做网页,那时也没有前端和后端的区分,有时一个网站就是一些纯静态的html,通过链接组织在一起.用过Dreamweaver的都知道,做网页就像用word编辑文档 ...

  4. 应用工具 .NET Portability Analyzer 分析迁移dotnet core

    大多数开发人员更喜欢一次性编写好业务逻辑代码,以后再重用这些代码.与构建不同的应用以面向多个平台相比,这种方法更加容易.如果您创建与 .NET Core 兼容的.NET 标准库,那么现在比以往任何时候 ...

  5. .NetCore中的日志(2)集成第三方日志工具

    .NetCore中的日志(2)集成第三方日志工具 0x00 在.NetCore的Logging组件中集成NLog 上一篇讨论了.NetCore中日志框架的结构,这一篇讨论一下.NetCore的Logg ...

  6. dll文件32位64位检测工具以及Windows文件夹SysWow64的坑

    自从操作系统升级到64位以后,就要不断的需要面对32位.64位的问题.相信有很多人并不是很清楚32位程序与64位程序的区别,以及Program Files (x86),Program Files的区别 ...

  7. Java基础Map接口+Collections工具类

    1.Map中我们主要讲两个接口 HashMap  与   LinkedHashMap (1)其中LinkedHashMap是有序的  怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...

  8. 渗透测试工具BurpSuite做网站的安全测试(基础版)

    渗透测试工具BurpSuite做网站的安全测试(基础版) 版权声明:本文为博主原创文章,未经博主允许不得转载. 学习网址: https://t0data.gitbooks.io/burpsuite/c ...

  9. CorelDRAW X8 如何破解激活(附国际版安装包+激活工具) 2016-12-15

    之前有位搞平面的好友“小瘦”说CDR X8无法破解,只能用X7.呃……呃……呃……好像是的 其实CDR8难激活主要在于一个点“没有离线激活了,只可以在线激活”,逆天不是专供逆向的,当然没能力去破解,这 ...

随机推荐

  1. iOS网络-06-监听Iphone的网络状态

    使用系统的方法来监听网络状态 系统的方法是通过通知机制来实现网络状态的监听 实现网络状态监听的步骤 定义Reachability类型的成员变量来保存网络的状态 @property (nonatomic ...

  2. javascript 调试技巧

    不用alert,用console.log() <!DOCTYPE html> <html> <head> <script type="text/ja ...

  3. (传输层)UDP协议

    目录 数据单位特点具体实现要求UDP首部格式发送UDP请求的客户端图释 数据单位 UDP 传送的数据单位协议是 UDP 报文或用户数据报 特点 UDP 是无连接的,即发送数据之前不需要建立连接 UDP ...

  4. 单元测试_JUnit4的应用与实践

    本文实例为:JUnit4+Eclipse+CVS的实践 目录 1.测试环境搭建 1.1 JDK安装部署 1.2 Eclipse安装部署 1.3 Eclipse添加JUnit4 1.4 CVS项目文件引 ...

  5. apt-get报错could not get lock /var/lib/dpkg/lock -open等

    用apt-get命令安装一些软件包时,总报错:E:could not get lock /var/lib/dpkg/lock -open等 出现这个问题的原因可能是有另外一个程序正在运行,导致资源被锁 ...

  6. Remote Desktop Connection Manager (RDCMan) 介绍

    Remote Desktop Connection Manager介绍 Remote Desktop Connection Manager (RDCMan) 是微软Windows Live体验团队的主 ...

  7. 解决ubuntu sudo not found command的问题

    将/etc/sudoers 中Defaults env_reset改成Defaults !env_reset取消掉对PATH变量的重置, 然后在/etc/bash.bashrc中最后添加alias s ...

  8. virtualbox 在window10上的兼容性调整

    更新完windows10后,打开当时的virtualbox 4.3.3已经是最新的啦,打开原来安装的几个虚拟机(hadoop),发现均失败. 打开setting一看,网络一栏有问题,桥接模式的虚拟机都 ...

  9. gre网络细节

    一.OpenStack网络设备的命名规律: 1.TenantA的router和Linux网络命名空间qrouter名称 root@controller:~# neutron --os-tenant-n ...

  10. 使用nmon监控服务器性能

    1.下载nmon:http://nmon.sourceforge.net/pmwiki.php?n=Site.Download 2.选择适合Linux系统版本的相应nmon版本,Linux查看系统版本 ...