常用命令

  1. 函数的rest参数和扩展
  2. promise使用
  3. module.exports和Es6 import/export的使用
function sum(x,y,z){
        let total = 0;
        if(x)total+=x;
        if(y)total+=y;
        if(z)total+=z;
    }
    sum(5,"",9);
    function sum2(...m){
        let total = 0;
        for(var i of m){
            total += i;
        }
        console.log(`total${total}`)
    }
    sum2(4,8,9,10,5);
    let sum3 = (...m)=>{
      let total = 0;
      for(var i of m){
        total += i;
      }
      console.log(`total${total}`)
    }
    sum3(4,8,9,10,5);
    var [x,y] = [4,8];
    console.log(...[4,8])
    let arr1 = [1,3];
    let arr2 = [4,8];
    console.log("concat:"+arr1.concat(arr2));
    //[...arr1,...arr2];
    let [a,b,c]="ES6";
    console.log(a);//输出E

  

let checkLogin = function(){
        return new Promise(function(resolve,reject){
            let flag = document.cookie.indexOf("userId")>-1?true:false;
            if(flag=true){
                resolve({
                    status :0,
                    result:true
                })
            }else{
                reject("error")
          }
        })
    };
    let getUserInfo = ()=>{
        return new Promise((resolve,reject)=>{
            let userInfo={
                userId:"101 "
            }
            resolve(userInfo);
      })
    };
    checkLogin().then((res)=>{
        if(res.status == 0){
            console.log("login success")
          return getUserInfo();
        }
    }).catch((error)=>{
        console. log(`error:${error}`);
    }).then((res2)=>{
        console.log(`userId${res2.userId}`)
    })
    Promeise.all([checkLogin(),getUserInfo( )]).then(([res1,res2])=>{
        console.log(`result:${res1.result},result:${res2.result}`)
    })
 //promise
    let checkLogin = function(){
        return new Promise(function(resolve,reject){
            let flag = document.cookie.indexOf("userId")>-1?true:false;
            if(flag=true){
                resolve({
                    status:0,
                    result:true
                })
            }else{
                reject("error")
          }
        })
    };
    let getUserInfo = ()=>{
        return new Promise((resolve,reject)=>{
            let userInfo={
                userId:"101"
            }
            resolve(userInfo);
      })
    };
    checkLogin().then((res)=>{
        if(res.status == 0){
            console.log("login success")
          return getUserInfo();
        }
    }).catch((error)=>{
        console.log(`error:${error}`);
    }).then((res2)=>{
        console.log(`userId${res2.userId}`)
    });
    Promeise.all([checkLogin(),getUserInfo()]).then(([res1,res2])=>{
        console.log(`result:${res1.result},result:${res2.result}`)
    })

  


  

ES6笔记总结的更多相关文章

  1. ES6笔记(5)-- Generator生成器函数

    系列文章 -- ES6笔记系列 接触过Ajax请求的会遇到过异步调用的问题,为了保证调用顺序的正确性,一般我们会在回调函数中调用,也有用到一些新的解决方案如Promise相关的技术. 在异步编程中,还 ...

  2. ES6笔记系列

    ES6,即ECMAScript 6.0,ES6的第一个版本是在2015年发布的,所以又称作ECMAScript 2015 如今距ES6发布已经一年多的时间,这时候才去学,作为一个JSer,羞愧羞愧,还 ...

  3. ES6笔记(1) -- 环境配置支持

    系列文章 -- ES6笔记系列 虽然ES6已经发布一年多了,但在各大浏览器之中的支持度还不是很理想,在这查看ES6新特性支持度 Chrome的最新版本浏览器大部分已经支持,在Node.js环境上支持度 ...

  4. ES6笔记(2)-- let的块级作用域

    系列文章 -- ES6笔记系列 一.函数级作用域 我们都知道,在ES6以前,JS只有函数级作用域,没有块级作用域这个概念 没有块级作用域,有利有弊,利于方便自由,弊于作用域内的变量容易被共享,例如这个 ...

  5. ES6笔记(3)-- 解构赋值

    系列文章 -- ES6笔记系列 解构赋值,即对某种结构进行解析,然后将解析出来的值赋值给相关的变量,常见的有数组.对象.字符串的解构赋值等 一.数组的解构赋值 function ids() { ret ...

  6. ES6笔记(4)-- Symbol类型

    系列文章 -- ES6笔记系列 Symbol是什么?中文意思是标志.记号,顾名思义,它可以用了做记号. 是的,它是一种标记的方法,被ES6引入作为一种新的数据类型,表示独一无二的值. 由此,JS的数据 ...

  7. ES6笔记(6)-- Set、Map结构和Iterator迭代器

    系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java.C++,连Iterator迭代器.Set集合.Map结构都出来了,不知道说什么好... 一.简单使用 1. iter ...

  8. ES6笔记(7)-- Promise异步编程

    系列文章 -- ES6笔记系列 很久很久以前,在做Node.js聊天室,使用MongoDB数据服务的时候就遇到了多重回调嵌套导致代码混乱的问题. JS异步编程有利有弊,Promise的出现,改善了这一 ...

  9. ES6 笔记汇总

    ES6 笔记汇总 二.ES6基础-let和const命令 三.变量的解构赋值 四.字符串的拓展 五.正则表达式的拓展 ...将会持续更新,敬请期待

  10. ES6笔记2

    ES6笔记2 Promise Promise 是 ES6 引入的异步编程的新解决方案,语法上是一个构造函数 一共有3种状态,pending(进行中).fulfilled(已成功)和rejected(已 ...

随机推荐

  1. iOS开发:Toast for iPhone

    iOS开发:Toast for iPhone   分享一个我写的类似于android的toast的提示框 主要特点: 1,支持屏幕Y轴任意位置显示,设置距离顶/底端距离 2,支持多行文本 3,支持设置 ...

  2. 换站点Logo图片---轻开电子商务系统(企业入门级B2C站点)

    一共2个文件: 显示及上传文件:site/links/img_logo.html 保存图片文件:site/links/img_logo_up1.chtml 在轻开电子商务系统(企业入门级B2C站点)的 ...

  3. IGP和EGP(转载)

    AS(自治系统) - 也称为路由域,是指一个共同管理区域内的一组路由器.例如公司的内部网络和 Internet 服务提供商的网络.由于 Internet 基于自治系统,因此既需要使用内部路由协议,也需 ...

  4. 【caffe-windows】 caffe-master 之 卷积核可视化(利用matlab)

    此篇是利用matlab对caffemodel的卷积核进行可视化.只介绍了卷积核的可视化,不涉及特征图的可视化. 是参考此博客: http://blog.csdn.net/zb1165048017/ar ...

  5. EasyDarwin开源流媒体server将select改为epoll的方法

    本文来自EasyDarwin团队Fantasy(fantasy(at)easydarwin.org) 一. EasyDarwin网络模型介绍 EventContext负责监听全部网络读写事件.Even ...

  6. jquery 备忘笔记

    1.选择器 a.查询所有以某字符串开头的元素 $("input[id^='dgItem_txt']") b.获取一组单选按钮中选中的值 $("input[name='it ...

  7. Snow White,摘自iOS应用Snow White and more stories

    Once upon a time, there was a land. 从前,有个国度. It was ruled by an evil queen. 它被一位邪恶的女王统治. Every day t ...

  8. 虚拟化(五):vsphere高可用群集与容错(存储DRS是一种可用于将多个数据存储作为单个数据存储群集进行管理的功能)

    vsphere高级功能需要vcenter server和共享存储的支持才能实现.vsphere的高级功能有 vmotion.storage vmotion.vsphere HA.vsphere DRS ...

  9. Codeforces Round #373 (Div. 2) Anatoly and Cockroaches —— 贪心

    题目链接:http://codeforces.com/contest/719/problem/B B. Anatoly and Cockroaches time limit per test 1 se ...

  10. 如何刷新本地的DNS缓存?

    为了提高网站的访问速度,系统会在成功访问某网站后将该网站的域名.IP地址信息缓存到本地.下次访问该域名时直接通过IP进行访问.一些网站的域名没有变化,但IP地址发生变化,有可能因本地的DNS缓存没有刷 ...