Node.js+Ajax实现物流小工具
半年过去了,好像什么也没干,好像什么也干了。
最近在网易云课堂上看到了这个课程,觉得很有意思,就跟着课程做了一遍,课程地址:http://study.163.com/course/courseMain.htm?courseId=1004615001。
1. NPM和Webpack
之前专门了解了一下这两者,但是看完之后没有实际应用过,很快就忘了,这次借着这个项目又学了一遍。
说到NPM就不得不说Node,Js语言原来只能被浏览器解析,为网页提供动态效果,Node.js是一个Js语言的Runtime environment,Node是节点的意思,将Js和操作系统连接,使得Js能在服务器端运行。电脑安装了Node环境后,会自带NPM工具。在工程项目中,我们会遇到很多类似的问题,通常将解决办法封装成一个包,以便进行复用,有时,一个庞大的项目可能有很多包,包之间的联系也非常复杂,所以我们需要NPM这样一个工具来高效地管理这些包 / 模块/ 依赖。使用基本步骤:进入文件夹 — 安装所需的包 — 配置项 — 常用命令,要注意的是安装包时要区分开发环境和生产环境,如果速度太慢,可以使用淘宝的NPM镜像。
Webpack可通过NPM直接安装,主要解决的是前端历史发展中遗留下来的问题,即新需求与旧标准之间的矛盾。如果直接以后端的方式写模块化的代码,浏览器是无法正确解析的,而在Node模式下能够将一个Js代码里面的一些接口暴露出去,供其他的模块调用。大量的Js文件经过Webpack处理之后,会生产一个bundle.js文件,项目里只要引用该文件即可。
2. Ajax
1) Ajax的请求过程:
创建请求对象 — 配置请求对象的属性 — 设置回调函数 — 发送请求
2) 请求对象的属性:
readyState //请求在其生命周期的哪个阶段 2
status //服务器返回的http状态,200一切正常 3
statusText
responseText //服务器返回的响应数据 4
respomseXML onreadystatuschange //服务器响应是调用哪个函数 1
3) 请求状态(请求在其生命周期的哪个阶段):
创建请求对象后readyState的变化过程 //request=createRequest();
0 :连接尚未初始化 //request.open("GET",url,true);
1 :连接初始化,请求已准备好可以发送 //request.send(null);
2 :服务器正在处理请求
3 :得到服务器响应,响应数据还在准备中
4 :服务器响应就绪,调用回调函数
3. 项目实现
这个小项目的实现主要分为两部分,前端页面和后台,后台获取数据并把物流数据传给前端页面进行展示。前端页面实现起来比较简单,在框架写好后用chrome开发者工具进行微调,用左上角的选择工具选中要修改的元素,在对它进行调整,查看页面显示效果即可。页面做好后为查询按钮添加点击事件,用Ajax实现快递信息的请求。
$("#submit").click(function(){
$(".prop").show();
$(".result-box").empty();
var type = $("#select").val();
var postid = $("#search").val();
var url = 'http://localhost:3000/query';
$.ajax({
type:'get',
url:url,
data:{type:type,postid:postid},
success:function(data){
$(".prop").hide();
try{
var obj = JSON.parse(data)
console.log(obj.data[0]);
$("#search_result").text(obj.message);
for(var x=0;x<data.length;x++){
$(".result-box").append(' <div class="result">\n' +
' <div class="time">'+obj.data[x].time+' </div>\n' +
' <div class="context">'+obj.data[x].context+'</div>\n' +
' <div class="cleafix"></div>\n' +
' </div>');
}
}catch (err){
console.log(err)
}
}
})
})
下图是用NPM配置后的文件目录:

<script src=".././后台/nodeProject_2/node_modules/jquery/dist/jquery.js"> (./ 当前层级)
后端使用了express框架,在webstorm中添加服务器,具体物流信息数据从快递100网的接口获取。

Node.js+Ajax实现物流小工具的更多相关文章
- 认识Web前端、Web后端、桌面app和移动app新开发模式 - 基于Node.js环境和VS Code工具
认识Web.桌面和移动app新开发模式 - 基于Node.js环境和VS Code工具 一.开发环境的搭建(基于win10) 1.安装node.js和npm 到node.js官网下载安装包(包含npm ...
- node.js 开发简易的小爬虫
node.js 开发简易的小爬虫 最近公司开发一款医药类的软件,所以需要一些药品的基础数据,所以本人就用node.js写一个简易的小爬虫,并写记录这个Demo以供大家参考. 一.开发前的准备: 1, ...
- 【Node.js】2.开发Node.js选择哪个IDE 开发工具呢
安装完Node.js之后,就要为它选择一个有利的IDE用于开发. 相比较了多个IDE之后,定位在webstrom和sublime上. 有一个简单的比较: webstorm功能很丰富,前端开发工具的集大 ...
- 微软开放技术发布针对 Mac 和 Linux 的更新版 Azure Node.JS SDK 和命令行工具
发布于 2013-12-04 作者 Eduard Koller 这次为我们使用Linux 的朋友带来了更多关于部署云上虚拟机的消息.今天,微软开放技术有限公司 (MS Open Tech),想与大家分 ...
- node.js如何制作命令行工具(一)
之前使用过一些全局安装的NPM包,安装完之后,可以通过其提供的命令,完成一些任务.比如Fis3,可以通过fis3 server start 开启fis的静态文件服务,通过fis3 release开启文 ...
- node.js中npm包管理工具
现在安装node.js,默认就会帮我们装上了npm包管理工具,npm主要用来下载,安装,管理第三方模块. 创建一个包描述文件: npm init [-y] 查看包的信息 npm info <pa ...
- 【node.js】全局变量、常用工具、文件系统
学习链接:http://www.runoob.com/nodejs/nodejs-global-object.html 在 JavaScript 中,通常 window 是全局对象, 而 Node.j ...
- Node.js Koa2开发微信小程序服务端
1.promise.async.await const Koa = require('koa') const app = new Koa() // 应用程序对象 有很多中间件 // 发送HTTP KO ...
- 在Sublime Text3 开发Node.js遇到的一个小问题
原文摘自我的前端博客,欢迎大家来访问 http://www.hacke2.cn 以前的Sublime Text 2包管理出现问题了,不能安装新包,让人开发很捉急,今天装了个3,这个问题解决了 那我们就 ...
随机推荐
- Mysql的select in会自动过滤重复的数据
默认使用 SELECT 语句: 当加上in范围后,结果如下图: in范围内的数据,如果有重复的,只会选择第一个数据. 所以如果不是直接使用SQL语句来查询,而是在代码中来查询时,记得使用 distin ...
- SpringBoot入门 (十三) WebSocket使用
本文记录在SpringBoot中使用WebSocket. 一 什么是WebSocket WebSocket是基于TCP协议的一种网络协议,它实现了浏览器与服务器全双工通信,支持客户端和服务端之间相互发 ...
- 【sh文件权限】无法启动tomcat -bash: ./startup.sh: Permission denied
今天在Linux上启动Tomcat,结果弹出:-bash: ./startup.sh: Permission denied 的提示. 这是因为用户没有权限,而导致无法执行, 用命令chmod 修改一下 ...
- html5标签属性translate
定义 translate 是指标签属性,不是css3样式规则transform的translate,说它的定义吧:规定是否应该翻译元素内容. 了解:translate是HTML5中的新属性 语法 &l ...
- ApiGen 4.0配置项
Usage: generate [-s|--source="..."] [-d|--destination="..."] [--access-levels=&q ...
- 【SpringBoot系列1】SpringBoot整合MyBatis
前言: 一直看网上说SpringBoot是解锁你的配置烦恼,一种超级快速开发的框架.一直挺想学的,正好最近也有时间,就学了下 这个是SpringBoot整合MyBatis的一个教程,用了阿里的drui ...
- HTTPS知识小结
HTTPS知识小结 背景1:TCP握手 internet上的两台机器A,B要建立起HTTP连接了,在这之前要先建立TCP连接,情景大概是这样子的: A:你好,我跟你建立一个TCP好吗? B:好啊. A ...
- Net Core 中间件实现修改Action的接收参数及返回值
新一个WebApi项目(Net Core 2.1) 新建InputOutputAlterMiddleware类,修改命名空间为Microsoft.AspNetCore.Builder(不修改也没关系, ...
- 如何查看是否安装.NET Framework、.NET Framework的版本号以及CLR版本号
查看是否安装.NET Framework→%SystemRoot%\System32→如果有mscoree.dll文件,表明.NET Framework已安装 查看安装了哪些版本的.NET Framw ...
- 第15课-数据库开发及ado.net-数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库
第15课-数据库开发及ado.net 数据库介绍,主键,外键,启动数据库,数据库身份验证方式,建表,分离数据库 1. 学习方法 2. 多涨见识 3. 比自己强的人一起,学习更强:比自己更聪明的人 ...