博客列表 >js 中数组常用方法介绍以及 JSON 对象的两个方法展示和跨域请求问题解决方案

js 中数组常用方法介绍以及 JSON 对象的两个方法展示和跨域请求问题解决方案

祥子弟弟
祥子弟弟原创
2021年02月07日 15:05:44709浏览

一、js 中数组常用方法

1.push()方法:在数组的尾部插入一个元素

  1. let arr = [];
  2. arr.push(1);
  3. arr.push(2);
  4. arr.push(3);
  5. console.log(arr);
  6. // arr = [1, 2, 3];

2.pop()方法:从数组的尾部进行弹出操作,返回值是弹出的值,进行 pop 操作后,数组中相对应位置的值会删除

  1. console.log(arr.pop());
  2. //3
  3. console.log(arr.pop());
  4. //2
  5. console.log(arr.pop());
  6. //1

3.unshift()方法:在数组的头部插入一个元素

  1. arr.unshift(1);
  2. arr.unshift(2);
  3. arr.unshift(3);
  4. console.log(arr);
  5. // arr = [3,2,1];

4.shift()方法:从数组的头部弹出一个元素

  1. console.log(arr.shift());
  2. //3
  3. console.log(arr.shift());
  4. //2
  5. console.log(arr.shift());
  6. //1

5.join()方法:与字符串的 split()方法相反,它是将数组转为字符串返回一个新的字符串

  1. arr = ["电脑", "手机", "耳机", "手表", "折刀"];
  2. let res = arr.join();
  3. // join()的默认参数是 ',' ,使用逗号将数组元素隔开
  4. console.log(res);
  5. // res = "电脑,手机,耳机,手表,折刀";
  6. res = arr.join("和");
  7. console.log(res);
  8. // res = "电脑和手机和耳机和手表和折刀";
  9. // js中的字符串是可以当数组一样使用的,支持索引取字符串中的字符

6.concat()方法:数组合并

  1. console.log([1, 2, 3].concat([4, 5], [6, 7]));
  2. // [1, 2, 3, 4, 5, 6, 7];
  3. // concat()方法中的参数不一定是数组类型,其他的都可以
  4. console.log([1, 2, 3].concat(456, "小花", true, { a: 1, b: 2 }));
  5. //[1, 2, 3, 456, "小花", true, {…}];
  6. // 可以看到的是,它会将所有的数据全部合并到一个数组中,其中每项都是数组的一个元素
  7. // concat()方法的返回一定是一个一维数组,它里边的参数如果包含一个数组,或是多个数组,它并不会生成一个多维数组,而是将里边的数组参数展开,然后进行合并

7.slice(起始位置,选取的数量)方法:获取数组中的部分成员

  1. // 创建数组副本使用,支持负数操作,取值方向是从左至右
  2. arr = [1, 2, 3, 4, 5];
  3. // 数组的深拷贝方式,和使用for循环添加的性质相似
  4. res = arr.slice(0);
  5. console.log(res);
  6. //[1, 2, 3, 4, 5];

8.splice(开始索引,删除的数量,插入的数据…)方法:数组的增删改,它的主要工作是删除元素

  1. // 删除
  2. // 从索引是2的元素开始删除,没有第二个参数,就代表从当前开始一直删完,它的返回值是删除的元素
  3. res = arr.splice(2);
  4. console.log(res);
  5. console.log(arr);
  6. // 更新操作
  7. arr = [1, 2, 3, 4, 5];
  8. // 例如将2,3更新成22,33
  9. // res = arr.splice(1, 2, 22, 33);
  10. // 第三个参数不支持数组传参,不管是多少个值,都必须写成单值,不过可以使用...rest合并参数方法进行简写
  11. res = arr.splice(1, 2, ...[22, 33]);
  12. console.log(res);
  13. console.log(arr);
  14. // 新增操作
  15. arr = [1, 2, 3, 4, 5];
  16. // 将第二个参数设置为0,这样就不会有元素被删除
  17. res = arr.splice(1, 0, ...[22, 33]);
  18. console.log(res);
  19. console.log(arr);

9.sort()方法:对数组中的元素进行排序

  1. arr = ["a", "s", "i", "y"];
  2. console.log(arr);
  3. console.log(arr.sort());
  4. // 如果说,数组中出现其它类型的数据,就会报错
  5. arr = [47, 79, 4, 2, 8, 83, 2];
  6. console.log(arr);
  7. console.log(arr.sort());
  8. // 使用自定义方式来进行
  9. // 这里使用回调函数的方式来自定义
  10. //升序
  11. console.log(arr.sort((a, b) => a - b));
  12. //降序
  13. console.log(arr.sort((a, b) => b - a));

10.filter()方法:进行数组中的元素过滤筛选

  1. arr = [1, 2, 3, 4, 5];
  2. // filter()方法中的参数是过滤规则
  3. res = arr.filter((item) => item % 2);
  4. console.log(res);
  5. //[1, 3, 5];
  6. res = arr.filter((item) => !(item % 2));
  7. console.log(res);
  8. //[2, 4];

二、JSON 对象的两个方法

JSON: JavaScript Object Notation(JS 对象表示法),它独立于任何编程语言, 几乎所有编程语言都提供了访问 JSON 数据的 API 接口,JSON 是一种语法,用来序列化其它语言创建的数据类型。

JSON 对象中的两个方法分别是:
1.JOSN.stringify(data(js 数据),replacer(对数据的处理方式), space(限定输出格式)):将 js 数据转为 JSON
2.JSON.parse(str, reviver),将 JSON 转为 js 对象

1.JOSN.stringify()方法:将 JS 数据转换成 JSON 类型

JSON.stringify() 方法将一个 JS 对象或值转换为 JSON 字符串,如果指定了一个 replacer 函数,则可以选择性地替换值,或者指定的 replacer 是数组,则可选择性地仅包含数组指定的属性。

  1. console.log(JSON.stringify(555), typeof JSON.stringify(555));
  2. //555 string;
  3. // JSON中字符串要加引号
  4. console.log(JSON.stringify("aaa"), typeof JSON.stringify("aaa"));
  5. //"aaa" string;
  6. console.log(JSON.stringify(true), typeof JSON.stringify(true));
  7. //true string;
  8. console.log(JSON.stringify(null), typeof JSON.stringify(null));
  9. //null string;
  10. // JSON中对象的属性必须加双引号,字符串也一样
  11. console.log(
  12. JSON.stringify({ a: 1, b: 2 }),
  13. typeof JSON.stringify({ a: 1, b: 2 })
  14. );
  15. //{"a":1,"b":2} string;
  16. console.log(JSON.stringify([1, 2, 3]), typeof JSON.stringify([1, 2, 3]));
  17. //[1,2,3] string;
  18. // 第二个参数支持数组和函数
  19. // 数组
  20. console.log(JSON.stringify({ a: 1, b: 2, c: 3 }, ["a", "b"]));
  21. //{"a":1,"b":2};
  22. // 函数
  23. console.log(
  24. JSON.stringify({ a: 1, b: 2, c: 3 }, (k, v) => {
  25. if (v < 2) return undefined;
  26. return v;
  27. })
  28. );
  29. //{"b":2,"c":3};
  30. // 第三个参数,用来格式化输出JSON字符串
  31. // 第三个参数默认是空格输出,可以输入数字来控制空格数量,也可以输入自定义字符串
  32. console.log(JSON.stringify({ a: 1, b: 2, c: 3 }, null, "111"));
  33. //{111"a": 1,
  34. //111"b": 2,
  35. //111"c": 3
  36. //};

JSON 其实不是数据类型,只是一个具有特殊格式的字符串而已,由上边的示例可以看到的是,JSON 对象中只支持数值,字符串,null,布尔值,对象和数组这几种数据类型,并且所有 js 的数据转换成 JSON 对象都是字符串类型。

2.JSON.parse(str, reviver)方法:将 JSON 转换为 JS 对象

JSON.parse() 方法用来解析 JSON 字符串,构造由字符串描述的 JavaScript 值或对象。提供可选的 reviver 函数用以在返回之前对所得到的对象执行变换(操作)。

  1. let obj = JSON.parse(`{"a":1,"b":2}`);
  2. // console.log(obj);
  3. // 第二个参数控制哪些参数返回哪些不返回
  4. obj = JSON.parse(`{"a":1,"b":2}`, (k, v) => {
  5. // JSON对象解析是由内向外的
  6. if (k === "") return v;
  7. return v * 2;
  8. });
  9. console.log(obj);
  10. // {a: 2, b: 4};

三、跨域请求问题解决方案

1. Ajax (Asynchronus JavaScript+XML,即异步 JavaScript 加 XML) 异步请求技术

  • 同步与异步
    以 “前端请求,后端响应” 为例

    • 同步: 前端发请求, 必须等到后端响应完成,才允许发送另一个请求
    • 异步: 前端发请求后不等待后端响应结果继续执行,后端响应完成通过事件通知前端处理
  • XHR 对象: XMLHttpRequest 对象
    XHR 为发送服务器请求和获取响应提供了合理的接口,这个接口可以可以实现异步从服务器获取额外的数据,意味着用户点击不用页面刷新也可以从服务器获取数据。通过 XHR 对象获取数据之后,可以使用 DOM 方法将数据插入网页。

注意:XMLHttpRequest是浏览器对象,而非 JS 内置对象

  • 使用 XHR 对象实现 Ajax 异步请求操作
  1. 创建 xhr 对象: const xhr = new XMLHttpRequest()
  2. 配置 xhr 参数: xhr.open(type, url)
  3. 处理 xhr 响应: xhr.onload = (...) => {...}
  4. 发送 xhr 请求: xhr.send(...)
  • xhr 对象常用属性
序号 方法 描述
1 responseType 设置响应类型
2 response 响应正文
  • xhr 对象常用方法
序号 方法 描述
1 open(type,url) 配置请求参数
2 send(data/null) 发送请求
  • xhr 对象常用事件
序号 事件 描述
1 load() 请求成功
2 error() 请求失败

示例: 1.实现 Ajax 的异步 GET 请求

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>Ajax-GET异步请求</title>
  6. </head>
  7. <body>
  8. <button>ajax-get</button>
  9. <p></p>
  10. <script>
  11. const btn = document.querySelector("button");
  12. btn.onclick = () => {
  13. //1. 创建 xhr 对象:
  14. const xhr = new XMLHttpRequest();
  15. //2. 配置 xhr 参数:
  16. // open(请求类型,url)
  17. xhr.open("get", "test1.php?id=1");
  18. // 设置响应返回的数据类型为JSON
  19. xhr.responseType = "json";
  20. //3. 处理 xhr 响应:
  21. // 成功
  22. xhr.onload = () => {
  23. console.log(xhr.response);
  24. alert("ajax-get请求成功");
  25. // 返回成功,将响应结果渲染到页面中:进行dom操作
  26. let user = `${xhr.response.name}:(${xhr.response.email})`;
  27. document.querySelector("p").innerHTML = user;
  28. };
  29. // 失败
  30. xhr.onerror = () => {
  31. console.log("Error");
  32. document.querySelector("p").innerHTML = `请求失败`;
  33. };
  34. //4. 发送 xhr 请求:
  35. xhr.send(null);
  36. };
  37. </script>
  38. </body>
  39. </html>

测试返回结果

对于异步的 POST 请求原理是一样的,在第二步配置 xhr 参数的时候将第一个参数改成’post’就行了,不过 POST 请求一般是对表单数据进行操作,POST 请求的数据是携带在请求体中的,所以在第四步发送 xhr 请求的时候,需要对表单数据进行序列化处理,这时,可以使用FormData对象对表单数据进行处理。

  • FormData 对象

FormData是表单数据构造器

序号 方法 描述
1 append(name,value) 请求成功
2 delete(name) 请求失败

除了使用 append 方法添加数据之外,还可以直接传入一个表单元素,直接就将表单元素中的数据作为键/值对填充进去。

所以异步的 POST 操作仅仅需要修改两个部分: 1.在将实现步骤中的第二步配置 xhr 参数的时候,将第一个参数变为”post”; 2.第四步的发送 xhr 请求时,将发送的数据使用FormData 对象进行序列化

2. 跨域请求问题解决方案

通过 XHR 进行 Ajax 通信的一个主要限制是跨源安全策略。默认情况下,XHR 只能访问与发起请求的页面在同一个域内的资源(同源指:协议相同,域名(主机名)相同,端口号相同)。这个安全限制可以防止某些恶意行为。

  • 跨域资源共享( CORS, Cross-Origin Resource Sharing) 定义了浏览器与服务器如何跨源通信。
    CORS 的基本思路是使用自定义的 HTTP 头部允许浏览器和服务器互相了解,以确定请求或响应应该成功或失败。
  1. 通过在服务器端添加响应验证信息来实现跨域操作

对于简单的请求,比如说 GET 或者 POST 请求,没有自定义头部,而且请求体是 text/plain 类型,这样的请求在发送时会有一个额外的头部叫 OriginOrigin头部包含发送请求的页面的源(协议,域名和端口),以便服务器确定是否为其提供响应。下面是Origin头部的一个示例:(这个示例是我所创建的一个本地的服务器)
Origin: http://hello.io
如果服务器决定响应请求,那么应该发送Access-Control-Allow-Origin头部,包含相同的源,如果资源是公开的,那么头部信息包含就应该为 “*“关键字。这个关键字就代表这允许所有的页面进行访问,比如说,我想要服务器允许上边的域名 hello.io 进行访问,那么头部信息就应该为:header('Access-Control-Allow-Origin: http://hello.io');

所以说,GET 或者 POST 请求也是可以实现跨域资源访问的,只需要将服务端器设置成允许状态(服务器端 herder 头部信息包含 GET 或者 POST 请求页面的源)。

示例:使用 get 方法进行跨域操作

浏览器端代码

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>Ajax-GET请求跨域操作</title>
  6. </head>
  7. <body>
  8. <button>ajax-get-cors</button>
  9. <p></p>
  10. <script>
  11. // cors: 跨域资源共享
  12. // 同源策略:为了请求的安全,浏览器禁止通过脚本发起一个跨域的请求
  13. // 只允许脚本发起基于同源的请求
  14. const btn = document.querySelector("button");
  15. btn.onclick = (ev) => {
  16. // ev.preventDefault();
  17. //1. 创建 xhr 对象:
  18. const xhr = new XMLHttpRequest();
  19. //2. 配置 xhr 参数:
  20. xhr.open("get", "http://world.io/cors1.php");
  21. //3. 处理 xhr 响应:
  22. xhr.onload = () =>
  23. // document.querySelector("p").innerHTML = xhr.response;
  24. alert(xhr.response);
  25. //4. 发送 xhr 请求:get请求使用默认参数null,post请求要使用表单数据构造器FormData
  26. xhr.send(null);
  27. };
  28. </script>
  29. </body>
  30. </html>

服务器端代码

  1. <?php
  2. // 在服务器端开启跨域请求
  3. header('Access-Control-Allow-Origin: http://hello.io');
  4. // *: 表示任何来源都可以
  5. // header('Access-Control-Allow-Origin: *');
  6. echo 'CROS:跨域请求成功';

我设置的浏览器端的域名是 hello.io,服务器端的域名是 world.io,两者并不同源。

得到的效果:

2.使用 JSONP 来进行跨域操作

首先我们要知道能够直接跨域操作不受访问限制的成员都有
<script src="......"></script>:script 标签的 src 属性
<img src="....." alt="">: img 标签的 src 属性
<link rel="stylesheet" href=".....">: link 标签的 href 属性
<a href="..."></a>: a 标签的 href 属性
而 JSONP 就是利用了 script 标签中的 src 属性完成的跨域资源共享。

JSONP:JSON with padding, 它是 Web 服务上的一种 JSON 变体,是将 json 数据包含在一个函数调用中。它包括两部分: 回调函数 + json 数组。它实现跨域资源共享的原理是利用了 script 标签发起的请求不受跨域限制的特征,将跨域请求的 url 做为 script 的 src 属性值,实现不需要服务器授权的跨域请求(jsonp 只能完成 get 请求)

示例:使用 JSONP 实现跨域资源访问

  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="UTF-8" />
  5. <title>jsonp跨域资源共享</title>
  6. </head>
  7. <body>
  8. <button>json-cors</button>
  9. <p></p>
  10. <script>
  11. //1. jsonp的原理模拟
  12. function getUser(data) {
  13. let user = `${data.name}(${data.email})`;
  14. document.querySelector("p").innerHTML = user;
  15. }
  16. const btn = document.querySelector("button");
  17. btn.onclick = () => {
  18. //1. 生成一个允许跨域请求的html元素
  19. let script = document.createElement("script");
  20. // 2. 将跨域请求的url添加到src属性上
  21. script.src = "http://world.io/cors3.php?jsonp=getUser";
  22. // 3. 将script挂载到页面中
  23. document.body.insertBefore(script, document.body.firstElementChild);
  24. };
  25. // jsonp进行跨域主要是通过在服务器端生成一条js函数调用
  26. </script>
  27. </body>
  28. </html>
  1. <?php
  2. // jsonp 不需要授权给前端
  3. // 只需要返回一个使用json作为参数的函数调用语句
  4. // 将前端需要的数据以json格式放到函数的参数中
  5. // 必须要知道前端js需要调用的js函数名称
  6. $jsonp = $_GET['jsonp'];
  7. // 服务器中需要返回的数据
  8. $data = '{ "name": "小花", "email": "xh@xh,com" }';
  9. // 对返回的函数进行拼接
  10. echo $jsonp . '(' .$data .')';

返回的结果显示

JSONP 的缺点:
1.JSONP 是从不同的域拉取可执行代码,如果这个域并不可信,则可能在响应中加入恶意内容,此时除了完全删除 JSONP 没有任何办法。
2.不能准确的判断 JSONP 请求是否失败。

声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议