Ajax_Json用法

关于json的服务端代码

//首先在方法里面设置一个响应json数据对象

   const data = {
      name:'chenxigua'
  }

//因为 send只能接收字符串和Broadcast

所以 我们要先将对象进行一个字符串的转换 let str = JSON.stringify(data);

然后发送对象

response.send(data);

我们在客户端接收的data数据类型是已经被转换成了字符串形式的数据

所以我们要使用它就要进行一个格式的转换 我们转换数据的方法有两种

一种手动转换 一种是自动转换

手动转换

// 利用json.parse()来进行一个数据转换

// let data = JSON.parse(xhr.response);

// console.log(data);

这样data已经被我们转换成了一个对象数据类型

自动转换

自动转换我们只需要在创建请求的代码后加入代码转换

const xhr = new XMLHttpRequest();

//设置响应体数据的类型可以借助这段代码完成自动转换

xhr.responseType = 'json';

当代码加入完成后我们就可以直接使用

这时数据被控制台打印出来已经时已经是对象数据了

//自动转换

console.log(xhr.response);

result.innerHTML = xhr.response.name;

下面是完整的代码

server.js代码段


//1.引入express
// const { response } = require('express');
const express = require('express');

//2.创建应用对象
const app = express();

// 3.创建路由规则
//requser 是对请求报文的封装
//response 是对响应报文的一个封装
app.get("/server",(requset,response)=>{
  //设置响应头 设置允许跨域
  response.setHeader('Access-Control-Allow-Origin','*')

  // 设置响应体
  response.send("这是我传输过来的数据体!GET请求数据");
 
})
//all可以接收任意类型的请求
app.all("/json-server",(requset,response)=>{
  //设置响应头 设置允许跨域
  response.setHeader('Access-Control-Allow-Origin','*')
  //设置自定义响应头
  response.setHeader('Access-Control-Allow-Headers','*')
  //设置一个响应数据
  const data = {
      name:'chenxigua'
  }
  //要先将对象进行一个字符串的转换
  let str = JSON.stringify(data);

  // 设置响应体
  // send只能接收字符串和baser
   
  response.send(data);
 
})
// 4.监听端口启动服务
app.listen(8000,()=>{
  console.log("服务已经启动,8000 端口监听中...");
})

客户端代码段

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>AJax Json响应</title>
  <style>
      #result{
          width: 200px;
          height: 100px;
          border: solid 1px rgb(89, 184, 221);
      }
  </style>
</head>
<body>
  <div id="result"></div>
  <script>

      const result = document.getElementById('result');
      //绑定键盘按下事件
      window.onkeydown = function(){
          //发送请求
          const xhr = new XMLHttpRequest();

          //设置响应体数据的类型可以借助这段代码完成自动转换
          xhr.responseType = 'json';
           
          //初始化
          xhr.open('GET','http://localhost:8000/json-server');
          //发送
          xhr.send();
          //处理数据
          xhr.onreadystatechange = function(){
              if(xhr.readyState === 4){
                  if(xhr.status >=200 && xhr.status < 300){
                      // console.log(xhr.response);
                      // result.innerHTML = xhr.response;
                      //服务端传输过来的数据比较的麻烦 所以可以手动进行一个数据的处理
                      // 利用json.parse()来进行一个数据转换
                      // let data = JSON.parse(xhr.response);
                      // console.log(data);

                      //自动转换
                      console.log(xhr.response);
                      result.innerHTML = xhr.response.name;

                  }
              }
          }

      }

  </script>
</body>
</html>

Ajax_Json用法的更多相关文章

  1. EditText 基本用法

    title: EditText 基本用法 tags: EditText,编辑框,输入框 --- EditText介绍: EditText 在开发中也是经常用到的控件,也是一个比较必要的组件,可以说它是 ...

  2. jquery插件的用法之cookie 插件

    一.使用cookie 插件 插件官方网站下载地址:http://plugins.jquery.com/cookie/ cookie 插件的用法比较简单,直接粘贴下面代码示例: //生成一个cookie ...

  3. Java中的Socket的用法

                                   Java中的Socket的用法 Java中的Socket分为普通的Socket和NioSocket. 普通Socket的用法 Java中的 ...

  4. [转载]C#中MessageBox.Show用法以及VB.NET中MsgBox用法

    一.C#中MessageBox.Show用法 MessageBox.Show (String) 显示具有指定文本的消息框. 由 .NET Compact Framework 支持. MessageBo ...

  5. python enumerate 用法

    A new built-in function, enumerate() , will make certain loops a bit clearer. enumerate(thing) , whe ...

  6. [转载]Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法总结

    本文对Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法进行了详细的总结,需要的朋友可以参考下,希望对大家有所帮助. 详细解读Jquery各Ajax函数: ...

  7. 【JavaScript】innerHTML、innerText和outerHTML的用法区别

    用法: <div id="test">   <span style="color:red">test1</span> tes ...

  8. chattr用法

    [root@localhost tmp]# umask 0022 一.chattr用法 1.创建空文件attrtest,然后删除,提示无法删除,因为有隐藏文件 [root@localhost tmp] ...

  9. 萌新笔记——vim命令“=”、“d”、“y”的用法(结合光标移动命令,一些场合会非常方便)

    vim有许多命令,网上搜有一堆贴子.文章列举出各种功能的命令. 对于"="."d"."y",我在无意中发现了它们所具有的相同的一些用法,先举 ...

随机推荐

  1. react 结合antd 实现分页效果

    import React, { useState, useEffect } from "react"; // antd import { Pagination } from &qu ...

  2. 【PS算法理论探讨二】 Photoshop中图层样式之 投影样式 算法原理初探讨。

    接下来几篇文章我们将稍微简单的探索下PS中多种图层混合模式的算法内部原理,因为毕竟没有这方面的官方资料,所以很多方面也只是本人自己的探索和实践,有可能和实际的情况有着较大的差异. 在PS的实践中,图层 ...

  3. nim_duilib(3)之按钮

    introduction 更多控件用法,请参考 here 和 源码. 本文的代码基于这里 lets go xml文件添加代码 下面的xml文件内容,删除label控件的相关代码,增加了3个按钮. 其中 ...

  4. 【九度OJ】题目1179:阶乘 解题报告

    [九度OJ]题目1179:阶乘 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1179 题目描述: 输入n, 求y1=1!+3!+-m ...

  5. 【LeetCode】45. Jump Game II 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 贪心 日期 题目地址:https://leetcod ...

  6. 【LeetCode】825. Friends Of Appropriate Ages 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址:https://leetcode.com/problems/friends-o ...

  7. Chapter 15 Outcome Regression and Propensity Scores

    目录 15.1 Outcome regression 15.2 Propensity scores 15.3 Propensity stratification and standardization ...

  8. JS事件冒泡与事件捕获怎么理解?

    在js中存在事件冒泡与事件捕获两种概念,这两个概念都是为了解决页面中事件流(事件发生顺序)的问题. 事件冒泡(dubbed bubbling) 事件冒泡我们从字面意思理解就是当用户行为触发我们页面的定 ...

  9. HTML网页设计基础笔记 • 【第8章 页面布局与规划】

    全部章节   >>>> 本章目录 8.1 表格布局 8.1.1 表格布局 8.2 流式布局 8.2.1 瀑布流布局 8.2.2 masonry 实现瀑布流布局 8.3 div ...

  10. 编写Java程序_找星座朋友应用软件

    一.About the Project 项目介绍 自古以来,人对于恒星的排列和形状很感兴趣,并很自然地把一些位置相近的星联系起来,组成星座.占星术亦称"占星学"."星占学 ...