用promise获取新闻练习 、 class、指数运算符、Array.prototype.includes(value) 、字符串扩展、数值扩展、数组扩展、对象扩展

1、用promise获取新闻练习:

//定义获取新闻的功能函数

  function getNews(url){

    let promise = new Promise((resolve,reject) => {

      // 状态:初始化

      // 执行异步任务

      // 创建xmlHttp实例对象

      let xmlHttp = new XMLHttpRequest();

      console.log(xmlHttp.readyState);

      //绑定redayState监听

      xmlHttp.onreadystatechange = function(){

        if(xmlHttp.readyState === 4){ //全等于4,请求已完成

          if(xmlHttp.status == 200){//请求成功

            // console.log(xmlHttp.responseText);

            //修改状态

            resolve(xmlHttp.responseText);//修改promise的状态为成功的状态

          }else{//请求失败

            reject('暂时没有新闻内容');

          }

        }

      };

      // open设置请求的方式以及url

      xmlHttp.open('GET',url);

      // 发送

      xmlHttp.send();  //ajax请求发送

    })

    return promise;

  }

  getNews('http://localhost:3000/news?id=2')

    .then((data) => {

      console.log(data);

      // console.log(typeof data);

      // 准备获取评论内容的url

      let commentsUrl = JSON.parse(data).commentsUrl;

      let url = 'http://localhost:3000' + commentsUrl;

      // 发送请求获取评论内容

      return getNews(url);

    },(error) => {

      console.log(error);

    })

    .then((data) => {

      console.log(data);

    },() => {

    });

2、class:类

*通过class定义类/实现类的继承

* 在类中通过constructor定义构造方法

* 通过new来创建类的实例

* 通过extends来实现类的继承

* 通过super调用父类的构造方法

* 重写从父类中继承的一般方法

3、指数运算符(幂): **。console.log(2 ** 3);//8

4、Array.prototype.includes(value) :

判断数组中是否包含指定value

eg:console.log(arr.includes('a'));

5、字符串扩展:

includes(str) : 判断是否包含指定的字符串

startsWith(str) : 判断是否以指定字符串开头

endsWith(str) : 判断是否以指定字符串结尾

repeat(count) : 重复指定次数  eg:console.log(str.repeat(5));

6、数值扩展:

*二进制与八进制数值表示法: 二进制用0b, 八进制用0o

*Number.isFinite(i) : 判断是否是有限大的数

*Number.isNaN(i) : 判断是否是NaN

*Number.isInteger(i) : 判断是否是整数

*Number.parseInt(str) : 将字符串转换为对应的数值

*Math.trunc(i) : 直接去除小数部分

7、数组扩展:

*Array.from(v) : 将伪数组对象或可遍历对象转换为真数组

*Array.of(v1, v2, v3) : 将一系列值转换成数组

*find(function(value, index, arr){return true}) : 找出第一个满足条件返回true的元素

*findIndex(function(value, index, arr){return true}) : 找出第一个满足条件返回true的元素下标

8、对象扩展:

*Object.is(v1, v2):判断2个数据是否完全相等

*Object.assign(target, source1, source2..):将源对象的属性复制到目标对象上

*直接操作 __proto__ 属性

  let obj2 = {};

你可能感兴趣的:(用promise获取新闻练习 、 class、指数运算符、Array.prototype.includes(value) 、字符串扩展、数值扩展、数组扩展、对象扩展)