像在服务器上的操作,我们只要 require 引入的模块,只要不是 nodejs 中的模块,我们的下载环境都是开发环境    

  配置自动化:引用插件 nodemon

    下载:npm i nodemon -g   // 最好全局安装

    作用:之前,当我们改服务器的内容的时候,我们需要关闭服务器重新打开后,才能看到我们更改的内容;很不方便

       所以,他的作用就是,当我们改服务器的东西,只要 ctrl+s 保存后,服务器的东西自动更改,省的我们关闭服

       务器,然后在开启服务器这样子

    使用方法:nodemon "文件名"  // 之前都是 node "文件名" 来开启服务器,现在使用他即可

  模板引擎:引用插件 ejs  render 方法的使用  及 引用文件 renderFile 方法的使用

    下载:npm i ejs

    作用:之前我们用的 underscore 里面的 template 特别爽,模板的写法,现在 nodejs 也为我们提供了跟 underscore

       一样的东西,我们可以 <% js代码 %>  <%=引入数据 %>

    使用方法:  render() 第一个参数(必填):模板内容  第二个参数(必填):对象传参

      第一种:

        let ejs = require("ejs");

        let st = "hello";

        let dt = "<%=data %>world";

        let ft = ejs.render(dt,{data:st})

        console.log(ft)   // 打印的结果就是 helloworld

      第二种:

        let ejs = require("ejs");

        let st = {data:hello};

        let dt="<%=data %>world";

        let ft=ejs.render(dt,st);  

        console.log(ft)  // 打印的结果就是 helloworld

      以上这两种写法的区别,相信大家也看到了,就是 ejs.render() 中 第二个参数 必须是一个对象,只不过这个对象是什么时候写而已;

    renderFile() 的使用方法  将 文件 模板进行传参  有三个参数  第一个:文件  第二个:传参  第三个:回调函数

    我们在一个 ejs 文件上写上内容    

      

    看到没,与我们的 html 文件类型一致,然后,我们需要进行的操作 就是将 数据传给 data,最终将内容展示出来

    

    res.write()  往响应体里面些东西

    中间件:两个同样的功能,谁在前执行谁

    路由:对网址的伪装(我的理解)

      我们作为一个老实人,就会把具体的文件地址暴露出来,但是这样不好,别人也可以通过文件地址来访问我们的东西,包括秘密的文件,这当

    然不是一个好事情,所以我们需要对网址进行处理,让他们不再通过网络地址也能访问我们的内容,这样一来,问题就解决了,老板也会加个鸡腿

    案例:

    

    我们在 a.html 的内容是这样的

    

    来吧,让我们看看效果

    

    路由传参

      我们在网址上是这样写的:http://127.0.0.1:3000/a/12  (俗称:前端的请求)

      但是后台的匹配模式是这样的:"/a/:id"  这样的写法,我们通过 req.params 得到的结果为 id=12

    但是:以上的写法:会不会显得 low ,

  所以:让我们来使用高大上的东西:express 插件  这样的插件:使我们少写很多东西之外呢,也会让我们写的简单了不少;

    下载: npm i express --save  

      他的功能也是特别强大,我们来看一看吧

    第一个创建服务器:

      let express = require("express");

      let app = express()

      app.listen(3000)    // 这样我们便配好了一个 localhost:3000 的服务器

    第二个:创建根目录

      app.use(express.static("./www"));  // 这样我们就创建了一个 www 的根目录,且不需要我们在进行文件处理,因为 express 已经帮我们处理好了

    第三个:路由:

      说路由之前,我们先来说说前台的东西

      1. app.get()  代表所有 get 方式发送的请求,都有它来接收

      2. app.post()  代表所有 post 方式发送的请求,都有它来接收

      3. app.all()  不管是 get 方式,还是 post 方式,都可以接收他的请求

      对于请求的解析也是一件特别注意的事情

      如 get 方式 获取的参数

      这种方式

        let url = require("url");

        let querystring = require("querystring");  //  将网络地址参数进行解析

        let obj = url.parse(req.url)  // 这个是解析网络地址的,在上面的路由案例出现过

        let query = obj.query;    // 这里我们便能得到传参的字符串形式

        let cont = querystring.parse(query)  // 这里我们就可以将字符串形式转化成对象的形式

      get 方式通过 url 传输,只要我们将 url 种的 query 解析成对象,就可以获取参数  

      说实话,get 是 最简单的 ,post 可能需要处理的东西多一点;

      post 解析:需要下载插件 body-parser 且跟网络地址没有关系 

      下载:npm i body-parser --save

      这种方式

        let bodyParser = require("body-parser");

        let urlencodedParser = bodyParser.urlencoded({ extended: false })

        app.post('/login', urlencodedParser, function (req, res) {
            console.log(req.body)  // 这里面就是 post 请求的内容
        })
    接下来,我们看看 express 的路由实现,是多么幸福的一件事
      

    接下来实现路由传参

      

   效果图

    

node 常用模块的更多相关文章

  1. node常用模块---path

    path---用来提供文件路径和文件之间的处理的函数 node常用模块之path

  2. node常用模块汇总

    node常用模块汇总: 点击插件名字,查看使用文档 npm常用模块汇总 node常用模块汇总 gulp常用插件汇总 mkdirp:在node.js中像mkdir -p一样递归创建目录及其子目录

  3. node 常用模块及方法fs,url,http,path

    http://www.cnblogs.com/mangoxin/p/5664615.html https://www.liaoxuefeng.com/wiki/001434446689867b2715 ...

  4. npm常用模块汇总

    npm常用模块汇总: 点击插件名字,查看使用文档 npm常用模块汇总 node常用模块汇总 gulp常用插件汇总 npx 使用教程:npx使用教程 bable:bable这是JavaScript编译器 ...

  5. python学习笔记之常用模块(第五天)

    参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...

  6. day--6_python常用模块

    常用模块: time和datetime shutil模块 radom string shelve模块 xml处理 configparser处理 hashlib subprocess logging模块 ...

  7. Python学习笔记-常用模块

    1.python模块 如果你退出 Python 解释器并重新进入,你做的任何定义(变量和方法)都会丢失.因此,如果你想要编写一些更大的程序,为准备解释器输入使用一个文本编辑器会更好,并以那个文件替代作 ...

  8. Day5 - Python基础5 常用模块学习

    Python 之路 Day5 - 常用模块学习   本节大纲: 模块介绍 time &datetime模块 random os sys shutil json & picle shel ...

  9. 文成小盆友python-num7 -常用模块补充 ,python 牛逼的面相对象

    本篇内容: 常用模块的补充 python面相对象 一.常用模块补充 1.configparser模块 configparser 用于处理特定格式的文件,起内部是调用open()来实现的,他的使用场景是 ...

随机推荐

  1. 08 nginx+uWSGI+django+virtualenv+supervisor发布web服务器

    一.为什么要用nginx,uwsgi? 1 首先nginx 是对外的服务接口,外部浏览器通过url访问nginx, 2nginx 接收到浏览器发送过来的http请求,将包进行解析,分析url,如果是静 ...

  2. JDBC1

    ---恢复内容开始--- create table `account` ( `id` ), `name` ), `balance` ) ); insert into `account` (`id`, ...

  3. nodejs在Mac下的卸载

    卸载: 在 node 官网上下载的安装包,用安装包安装的node.应该可以用一下命令行卸载: 在终端输入以下命令: sudo rm -rf /usr/local/{bin/{node,npm},lib ...

  4. Storm项目开发纪要

    1.POM引用storm-core和javax.servlet-api这两个组件,如果本地模式跑拓扑,要把<scope>provided</scope>去掉:如果远程发布运行, ...

  5. psutil:系统、进程,信息都在我的掌握之中

    获取cpu的逻辑数量 import psutil print(psutil.cpu_count()) # 12 获取CPU的物理核心数 import psutil print(psutil.cpu_c ...

  6. zookeeper+activemq高可用集群搭建

    一.准备工作: 准备三台机器:192.168.35.111192.168.35.112192.168.35.113 二.搭建zookeeper 三台机器上均要搭建zookeeper服务// 下载zoo ...

  7. 服务器挂载 ntfs32 硬盘

    1,fdisk -l 查看硬盘名称 2,mount -t ntfs-3g /硬盘名/  /目标目录/ 3,umount   /硬盘名/ 4,如果卸载不了 就fuser -km /目标目录/

  8. Windows 聚焦的锁屏壁纸设置为桌面壁纸

    需求: Windows的锁屏壁纸偶尔遇到非常喜欢的壁纸,想设置为桌面壁纸. 步骤如下: 1. “Windows 聚焦”的锁屏壁纸都保存在隐藏文件夹 --- Assets里. a. 打开“资源管理器 b ...

  9. jQuery和Prototype的兼容性和冲突的多种解决方法

    有两种情况: 1.先加载Prototype,再加载jQuery. 2.先加载jQuery,再加载Prototype. 针对情况1:先加载Prototype,再加载jQuery.方法一:jQuery 库 ...

  10. Spring MVC HandlerMapping

    http://www.cnblogs.com/tengyunhao/p/7658952.html http://www.cnblogs.com/tengyunhao/p/7518481.html Sp ...