>웹 프론트엔드 >JS 튜토리얼 >간단한 Ajax 요청을 구현하는 jQuery+koa2의 예

간단한 Ajax 요청을 구현하는 jQuery+koa2의 예

亚连
亚连원래의
2018-06-01 09:39:271577검색

이 글에서는 간단한 Ajax 요청을 구현한 jQuery+koa2의 예를 주로 소개하고 참고용으로 올려보겠습니다.

머리말

과거에는 Ajax 코드를 작성할 때 프론트엔드 구현에만 집중했는데 이로 인해 Ajax 요청에 대한 이해가 부족하다고 느껴서 프론트엔드에서 Ajax 구현에 대한 간단한 데모를 작성했습니다. 간단한 GETPOST 요청을 구현하여 프런트엔드와 백엔드 상호 작용에 대한 이해를 심화했습니다. GETPOST请求,加深下对前后端交互的理解。

技术栈

  1. koa2

  2. jQuer

需求

某些逻辑可以直接在前端处理,这里发给后端处理是为了更好地理解Ajax请求。

POST

通过填写编号和姓名并发送POST请求来保存人员信息,当信息未填写或填写不正确时给出格式错误的提醒;当信息填写正确但编号已存在时给出编号已存在的提醒;当信息填写正确且编号不存在时显示保存成功。

GET

通过填写编号并发送GET请求来查询人员信息,当编号未填写或填写不正确时给出格式错误的提醒;当编号填写正确且编号已存在时返回人员信息;当信息填写正确但编号不存在时显示人员不存在的错误提醒。

文件列表

  1. dist

    1. index.html

    2. index.js

  2. server.js

  3. router.js

前端实现

html页面

index.html,简单的html页面,通过点击按钮发送json格式的Ajax请求:

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>Document</title>
 <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
</head>
<body>
 <p>
 <h1>Hello World</h1>
 <label for="person-number">编号</label>
 <input type="text" id="person-number">
 <label for="person-name">姓名</label>
 <input type="text" id="person-name">
 <button id="save">保存信息</button>
 <label for="search-number">编号</label>
 <input type="text" id="search-number">
 <button id="search">查询信息</button>
 <br>
 <br>
 <p id="message"></p>
 </p>
 <!-- jQuery实现代码 -->
 <script src="./index.js"><script>
</body>
</html>

jQuery发送Ajax请求

发送GET请求:

var searchButton = $(&#39;#search&#39;);
var personNumber = $(&#39;#person-number&#39;).val();
searchButton.click(() => {
 var number = $(&#39;#search-number&#39;).val();
 $.ajax({
 type: &#39;GET&#39;,
 url: `person/?number=${number}`
 })
});

发送POST请求:

var saveButton = $(&#39;#save&#39;).click(() => {
 var number = $(&#39;#person-number&#39;).val();
 var name = $(&#39;#person-name&#39;).val();
 $.ajax({
 type: &#39;POST&#39;,
 url: &#39;person&#39;,
 dataType: &#39;json&#39;,
 data: {
  number: number,
  name: name
 }
 })
});

处理返回的json数据

通过ajaxComplete事件处理返回的数据,这个事件只能绑定到document对象上:

// Ajax完成事件
$(document).ajaxComplete(function(event, xhr, settings) {
 var obj = JSON.parse(xhr.responseText);
 var data = obj.data;
 if(obj.success && data[&#39;number&#39;]){
 $(&#39;#message&#39;).text(`姓名:${data[&#39;name&#39;]} 编号:${data[&#39;number&#39;]}`);
 } else {
 $(&#39;#message&#39;).text(data);
 }
});

后端实现

web服务器

通过koa2来实现一个简单的Web服务器。server.js

const path = require(&#39;path&#39;);
const serve = require(&#39;koa-static&#39;);
const Koa = require(&#39;koa&#39;);
const koaBody = require(&#39;koa-body&#39;); // 解析 multipart、urlencoded和json格式的请求体
const router = require(&#39;./router.js&#39;);

const app = new Koa();

app.use(serve(path.join(__dirname, &#39;./dist&#39;))); // 读取前端静态页面
app.use(koaBody()); // 通过该中间件解析POST请求的请求体才能拿到数据
app.use(router.routes());
app.listen(3000);

console.log(&#39;listening on port 3000&#39;);

通过路由处理请求

处理GET请求,并以json字符串的形式返回数据。通过GET请求发送的查询参数会以对象字面量的形式保存在ctx.query属性中:

router.get(&#39;/person&#39;, (ctx, next) => {
 let number = ctx.query.number;
 let temp = {};
 // 判断编号是否存在
 temp.data = /^[0-9]+$/.test(number) ? (people[number] ? people[number] : &#39;编号不存在&#39; ) : &#39;编号格式错误&#39;;
 temp.success = !!temp.data[&#39;number&#39;];
 ctx.body = JSON.stringify(temp); // 响应请求,发送处理后的信息给客户端
});

处理POST请求,并以json字符串的形式返回数据。POST请求的数据保存在请求的请求体中,需要用koa-body中间件自动解析后才能通过ctx.request.body获取请求的数据:

router.post(&#39;/person&#39;, (ctx, next) => {
 let query = ctx.request.body;
 let temp = {};
 // 编号必须是数字并且大于0,名字必须存在
 if (/^[0-9]+$/.test(query.number) && query.name && parseInt(query.number, 10) > 0) {
 // 判断编号是否存在
 if (!people[query.number]) {
  // 保存信息
  people[query.number] = {
  number: parseInt(query.number, 10),
  name: query.name
  };
  temp.success = true;
  temp.data = &#39;保存成功&#39;;
 } else {
  temp.success = false;
  temp.data = &#39;编号已存在&#39;;
 }
 } else {
 temp.success = false;
 temp.data = &#39;信息格式错误&#39;;
 }
 ctx.body = JSON.stringify(temp);
});

完整的router.js:

const Router = require('koa-router');

const router = new Router();

// 初始的人员信息对象,信息从这里储存和读取。
const people = {
 1: { number: 1, name: 'Dan Friedell' },
 2: { number: 2, name: 'Anna Matteo' },
 3: { number: 3, name: 'Susan Shand' },
 4: { number: 4, name: 'Bryan Lynn' },
 5: { number: 5, name: 'Mario Ritter' },
};

router.get('/person', (ctx, next) => {
 let number = ctx.query.number;
 let temp = {}; // 要返回给客户端的对象,通过success属性判断存取是否成功。
 // 判断编号是否存在
 temp.data = /^[0-9]+$/.test(number) ? (people[number] ? people[number] : '编号不存在' ) : '编号格式错误';
 temp.success = !!temp.data['number'];
 ctx.body = JSON.stringify(temp);
});

router.post(&#39;/person&#39;, (ctx, next) => {
 let query = ctx.request.body;
 let temp = {};
 // 编号必须是数字并且大于0,名字必须存在
 if (/^[0-9]+$/.test(query.number) && query.name && parseInt(query.number, 10) > 0) {
 // 判断编号是否存在
 if (!people[query.number]) {
  // 保存信息
  people[query.number] = {
  number: parseInt(query.number, 10),
  name: query.name
  };
  temp.success = true;
  temp.data = &#39;保存成功&#39;;
 } else {
  temp.success = false;
  temp.data = &#39;编号已存在&#39;;
 }
 } else {
 temp.success = false;
 temp.data = &#39;信息格式错误&#39;;
 }
 ctx.body = JSON.stringify(temp);
});


module.exports = router;

测试

在控制台输入node server.js可以看到服务器在3000端口运行了,打开浏览器输入localhost:3000

기술 스택

  1. koa2

  2. jQuer

Requirements

someone 일부 로직은 프런트 엔드에서 직접 처리될 수 있으며 Ajax 요청을 더 잘 이해하기 위해 여기에서 처리하기 위해 백엔드로 전송됩니다.

POST

번호와 이름을 입력하여 사람 정보를 저장하고 POST 요청을 보냅니다. 정보가 채워지지 않거나 잘못 입력되면 정보가 입력될 때 형식 오류 알림이 제공됩니다. 정확하지만 번호가 이미 존재하는 경우, 존재 알림이 제공됩니다. 정보가 올바르게 입력되고 번호가 존재하지 않으면 저장이 성공합니다.

GET

번호를 입력하고 GET 요청을 보내 사람 정보를 쿼리합니다. 번호가 입력되지 않거나 잘못 입력되면 번호가 올바르게 입력되고 형식 오류 알림이 제공됩니다. 해당 번호가 이미 존재하는 경우 해당 인물 정보가 반환되며, 해당 정보가 올바르게 입력되었으나 해당 번호가 존재하지 않는 경우 해당 인물이 존재하지 않는다는 오류 메시지가 표시됩니다.

파일 목록

  1. dist

    1. index.html

    2. index.js
  2. server.js

  3. 라우터 .js

프런트 엔드 구현

html 페이지

🎜🎜index.html, 간단한 HTML 페이지, json을 보내세요. 코드> 형식의 <code>Ajax 요청 버튼을 클릭합니다: 🎜

🎜rrreee🎜🎜🎜🎜jQuery가 Ajax 요청을 보냅니다🎜🎜🎜 GET 요청을 보냅니다. 🎜

이벤트 처리에서 반환된 데이터는 document 개체에만 바인딩될 수 있습니다. 🎜

🎜rrreee🎜🎜 🎜🎜백엔드 구현🎜🎜🎜🎜 웹 서버🎜🎜🎜는 koa2를 통해 간단한 웹 서버를 구현합니다. server.js: 🎜

🎜rrreee🎜🎜🎜🎜경로를 통한 요청 처리 🎜🎜🎜 GET 요청을 처리하고 json으로 끝남 문자열 형식으로 데이터를 반환합니다. GET 요청을 통해 전송된 쿼리 매개변수는 객체 리터럴 형식으로 ctx.query 속성에 저장됩니다. 🎜

🎜rrreee🎜🎜 🎜 POST 요청을 처리하고 json 문자열 형식으로 데이터를 반환합니다. POST 요청의 데이터는 요청의 요청 본문에 저장되며 ctx.request를 통해 요청된 데이터를 얻으려면 먼저 <code>koa-body 미들웨어에 의해 자동으로 구문 분석되어야 합니다. 본문: 🎜🎜rrreee🎜🎜🎜전체 router.js:🎜

🎜rrreee🎜🎜🎜🎜Test🎜🎜 🎜node server.js를 입력하면 서버가 포트 3000에서 실행되고 있는 것을 볼 수 있습니다. 브라우저를 열고 localhost:3000를 입력하면 간단한 프런트 엔드 페이지가 표시됩니다. 🎜 🎜🎜🎜🎜데이터 쿼리: 🎜🎜🎜🎜🎜🎜🎜🎜 데이터 저장: 🎜🎜🎜🎜🎜데이터 다시 쿼리: 🎜🎜🎜🎜🎜위 내용은 모두에게 도움이 되기를 바랍니다. 앞으로도 다들. 🎜🎜관련 기사: 🎜🎜🎜실제 노드 정적 파일 서버의 샘플 코드🎜🎜🎜🎜🎜vue.js 또는 js 메소드로 중국어 A-Z 정렬 구현🎜🎜🎜🎜🎜vue.js 메소드로 배열 위치 이동 및 뷰 업데이트 동시에🎜 🎜🎜🎜🎜🎜🎜🎜🎜

위 내용은 간단한 Ajax 요청을 구현하는 jQuery+koa2의 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.