angular开发中对请求数据层的封装
一、本章节仅仅是对angular4
项目开发中数据请求封装到model
中
仅仅是在项目angular4项目部署结构的基础上扩展了,根据
javaweb
项目开发分层来说命名service
可能会好点,但是为了不与angular4
中本身就有的服务想冲突,本人取名为model
与数据层打交道的
二、项目结构
三、本章节使用到的技术点
- 1、封装了带头部信息的(可能出于安全考虑
CSRF
攻击类的,或者python-web
开发就必须要带tockend
头信息) - 2、简单的封装了
get
和post
请求的基础模型 - 3、把基础模型的类注入到项目开发中的接口模型中
- 4、
form
表单提交数据仅仅是利用的模板局部变量的方式获取输入框的值 - 5、使用代理解决开发过程中跨域的问题
- 6、使用
express
搭建一个后端服务器 - 7、
node
服务器对mySQL
数据库的查询与增加数据
四、重要代码描述
1、基础模型代码的封装
import { Injectable } from '@angular/core';
import { Http, Headers } from '@angular/http';
import { Observable } from 'rxjs/Observable';
import 'rxjs/Rx'; @Injectable()
export class ServiceBaseService {
constructor(private http: Http) { }
/**
* @param {string} url地址
* @param {any} [options]可选提交的参数
* @param {any} [header]可选设置的头信息
* @memberof ServiceBaseService
* @title: 封装一个get请求的基础类
*/
getData(url: string, options?: any, myheaders?: any): Observable<any> {
// 配置请求头
const myHeaders: Headers = new Headers();
// tslint:disable-next-line:forin
for (const key in myheaders) {
myHeaders.append(key, myheaders[key]);
};
url += (url.indexOf('?') < 0 ? '?' : '&') + this.param(options);
return this.http.get(url, { headers: myHeaders }).map(res => res.json());
} /**
* @param url地址
* @param options提交的数据
* @param myheaders可选参数设置头
* @title:封装一个post请求数据的
*/
postData(url: string, options: any, myheaders?: any): Observable<any> {
const myHeaders: Headers = new Headers();
myHeaders.append('Content-Type', 'application/json');
// tslint:disable-next-line:forin
for (const key in myheaders) {
myHeaders.append(key, myheaders[key]);
};
return this.http.post(url, options, { headers: myHeaders });
}
/**
* @param {any} data
* @returns
* @memberof ServiceBaseService
* @title:封装一个序列化get请求的参数的方法
*/
param(data): string {
let url = '';
// tslint:disable-next-line:forin
for (const k in data) {
const value = data[k] !== undefined ? data[k] : '';
url += `&${k}=${encodeURIComponent(value)}`;
}
return url ? url.substring(1) : '';
}
}
2、项目的根目录中创建
proxy.conf.json
解决跨域问题{
"/wiseoper/**": {
"target": "http://localhost:3000",
"secure": false
}
}
3、关于代理解决跨域的注意点请参考
4、关于
get
请求获取数据的模型import { Injectable } from '@angular/core';
import { ServiceBaseService } from 'app/model/service-base.service'; @Injectable()
export class GetServiceService { constructor(private serviceBase: ServiceBaseService) { }
// 获取数据
getData() {
const url = '/wiseoper/';
return this.serviceBase.getData(url, {name: 'hello', age: 20}, {QQ: '332904234'});
}
}
5、在组件的
component.ts
中直接调用模型中的方法就可以// 直接调用get请求数据的方法
getDate(): void {
this.getService.getData().subscribe(data => {
console.log(data);
});
}
6、可以从控制台上查看给请求头添加的内容
五、关于post
请问的封装
1、服务器代码
router.post("/wiseoper/register",(req,res)=>{
//如果是post提交数据就用req.body接收
console.log(req.body);
db("insert into cms_user(username,password) values(?,?)",[req.body.username,req.body.password],(err,data)=>{
console.log(err);
if (err){
res.json({
code:0,
info:"注册失败"
});
}
console.log(data);
if (data){
res.json({
code:1,
info:"注册成功"
});
}
})
});
2、
angular4
中对post
请求的封装/**
* @param url地址
* @param options提交的数据
* @param myheaders可选参数设置头
* @title:封装一个post请求数据的
*/
postData(url: string, options: any, myheaders?: any): Observable<any> {
const myHeaders: Headers = new Headers();
myHeaders.append('Content-Type', 'application/json');
// tslint:disable-next-line:forin
for (const key in myheaders) {
myHeaders.append(key, myheaders[key]);
};
return this.http.post(url, options, { headers: myHeaders });
}
angular开发中对请求数据层的封装
注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权
angular开发中对请求数据层的封装的更多相关文章
- angular开发中的两大问题
一.在我们的angular开发中,会请求数据但轮播图等...在请求过数据后他的事件和方法将不再执行: 看我们的解决方案一: app.controller("text",functi ...
- python web开发-flask访问请求数据request
Request对象在web应用的开发中是一个非常重要的对象,主要用来获取用户发来的请求数据. 常用属性参考:http://docs.jinkan.org/docs/flask/api.html#fla ...
- struts中的请求数据自动封装
Struts 2框架会将表单的参数以同名的方式设置给对应Action的属性中.该工作主要是由Parameters拦截器做的.而该拦截器中已经自动的实现了String到基本数据类型之间的转换工作.在st ...
- .Net中EF通用数据层小结
增删改查: using System; using System.Collections.Generic; using System.Data; using System.Data.Entity; u ...
- 接口测试中读取excel中的请求数据含有中文问题,UnicodeEncodeError: 'latin-1' codec can't encode character '\u5c0f' in position
错误信息:UnicodeEncodeError: 'latin-1' codec can't encode character '\u5c0f' in position 31: Body ('小') ...
- Struts2 请求数据的自动封装 及 自定义转换器类
请求数据自动封装: 实现原理:使用了参数拦截器.struts-default.xml中 <interceptor name="params" class="com. ...
- 瞎j8封装第二版之数据层的封装
看了以前写的代码,对就是下面这个 手把手封装数据层之DataUtil数据库操作的封装 觉得以前写的代码好烂啊!!!,重新理了一下思路,写得更规范和简练,应该效率也会高很多,用了一下下午写的连接池(半废 ...
- Hybrid混合开发中schema协议的使用与封装
混合开发中JS与APP通信的实现原理: JS通过schema协议,传递参数和全局回调函数给APP端 APP执行完(如微信扫一扫)后,调用协议中传入的回调函数,在前端执行回调处理. 默认写法: < ...
- react-native中的请求数据
很多移动应用都需要从远程地址中获取数据或资源.你可能需要给某个 REST API 发起 POST 请求以提交用户数据,又或者可能仅仅需要从某个服务器上获取一些静态内容. 使用 Fetch React ...
随机推荐
- [BZOJ2159]Crash的文明世界(斯特林数+树形DP)
题意:给定一棵树,求$S(i)=\sum_{j=1}^{n}dist(i,j)^k$.题解:根据斯特林数反演得到:$n^m=\sum_{i=0}^{n}C(n,i)\times i!\times S( ...
- 2017 icpc 西安网络赛
F. Trig Function 样例输入 2 0 2 1 2 2 样例输出 998244352 0 2 找啊找啊找数列和论文.cosnx可以用切比雪夫多项式弄成(cosx)的多项式,然后去找到了相关 ...
- Codeforces 741B Arpa's weak amphitheater and Mehrdad's valuable Hoses
[题目链接] http://codeforces.com/problemset/problem/741/B [题目大意] 给出一张图,所有连通块构成分组,每个点有价值和代价, 要么选择整个连通块,要么 ...
- [xsy2880]取石子游戏
题意:有$n$堆石子,每堆石子数量相同,以质因数分解给出,不停地从$1$到$n$依次拿石子,使得取完后石子个数为原来的因数(不能不取),当一堆只剩$1$个时结束,问在每堆石子结束的方案数 记石子个数为 ...
- Activity(活动)生命周期(2)--活动状态
每个活动在其生命周期中最多会有4种状态 一.运行状态 当一个活动位于返回栈的栈顶的时候,这时活动就处于运行状态.系统一般不会回收,因为这会带来非常差的用户体验 二.暂停状态 当一个活动不处于栈顶状态的 ...
- redis源码解析之内存管理
zmalloc.h的内容如下: void *zmalloc(size_t size); void *zcalloc(size_t size); void *zrealloc(void *ptr, si ...
- Android 权限处理
概述: 为了保护系统的完整性和用户隐私权,Android 在访问受限的沙盒中运行每款应用. 如果应用需要使用其沙盒以外的资源或信息,则必须明确请求权限. 根据应用请求的权限类型,系统可能会自动授予权限 ...
- #iOS问题记录#WKWebView 闪退异常
异常描述: pointer being freed was not allocated *** set a breakpoint in malloc_error_break to debug 问题描述 ...
- Linux 内核中的 GCC 特性
https://www.ibm.com/developerworks/cn/linux/l-gcc-hacks/ GCC 和 Linux 是出色的组合.尽管它们是独立的软件,但是 Linux 完全依靠 ...
- 修改activityMQ的登录账与密码
登录下管理员页面,ip根据实际的来 URL : http://127.0.0.1:8161/admin/ 默认账户密码都是admin 账户密码修改在conf文件夹下的jetty-realm.prope ...