//复习 1 .块级作用域  let 和const  2 变量结构  默认值 一般往后写  rest参数(了解)  箭头函数(重要)(x,y)=>{} 3.map 存储高级键值对  4.set集合(去重)
//集合内不存在重复
//es5 es6
console.log('----------------start----------------');
//1.块级作用域
//{
//    let a;

//}
// let 和 const 命令
// var声明变量放弃使用
//let 声明变量(node.js)
var a = 1;
{
   var a = 2;
   var b = 4;
   console.log(a);
}
console.log(a);

let f = 1;
{
   let f = 2;
   let g = 4;
}
console.log(f);

//等号左右结构一致可以赋值
let[a1,a2,a3]=[1,2,3];
console.log(a1+"---"+a2+"---"+a3);

const 声明常量
const c=5;

console.log(c);

let person={
   name:'guodongsheng',
   age:'21'
};
let{name,age}=person;
console.log("姓名:"+name+'年龄:'+age);

4 函数扩展 给函数加默认值

怎么样给x设置一个默认值
function test1(x=1) {
   console.log(x);
}

   test1();
   test1(100);

函数参数的个数不确定 如何初始化

function addNumbers(...values) {
   let sum = 0;
   for (let v of values) {
       sun += v;

   }
   return sum;
}

console.log(addNumbers(1,2,3));
console.log(addNumbers(1,2,3,4));

4.1 箭头函数
let func=(x,y) => {
   return x + y;
}

function comPute(x,y,f) {
   return f(x,y);
}

//let s=comPute(1,3, (x, y) => { return x + y; })
let s=comPute(1,3,func)

console.log(s);

5 数据结构--map
let m = new Map();//键值对 存储键值对

let person={
    name:'guodongsheng',
    age:'21'
};

// map和js对象都是存储键值对 但js对象的key只能是string 但map对象的key可以是任意

let teacher=
{
    name:'xuying',

    tel:'2222'
}

m.set(person,teacher);
console.log(m);

集合  没有重复 没有顺序
let s = new Set();

s.add(1);
s.add(1);
s.add(2);
s.add(2);

console.log(s);

//6 class  属性 方法   //属性不需要定义直接使用  //方法需要声明

class student
{

    // 构造函数 constructor  当对象创建的时候 自动调用 constructor constructor  constructor

    constructor()
    {
        //1 调用父类的constructor 如果有父类 super();

        //2设置属性初始值
        this.name='';//什么都不写为空 不分配的话是undefined
        //3 绑定自身函数
        this.SayHello=this.SayHello.bind(this);

    }
    SayHello(){
        console.log('my name is '+this.name);
    };
}
let s =new student();
s.name="guodongsheng";//属性不需要定义

s.SayHello();

console.log(s.name);

// 7.继承关系 extends  

class xiaoming extends student//类
{
    constructor()
    {
        //1 调用父类的constructor 如果有父类 super();
        super();
        //2设置属性初始值
        this.name='xiaomingxiaoming!!!';//什么都不写为空 不分配的话是undefined
        //3 绑定自身函数
        this.SayHello=this.SayHello.bind(this);

    }

    //开启异步
    start(callback){
        this.callback=callback;
        setTimeout(this.end.bind(this));
    }

    end(){
        console.log('end');
        if(this.callback)
        {
            this.callback();
        }

    }
}
 let t=new xiaoming();
 t.start(()=>{
    console.log('finish');
 });
 //箭头函数

//创建对象
let t =new xiaoming();
//t.name='xiaoming';
t.age=18;
t.SayHello();

//8.异步操作  callback();  Promise

class DoTaskPromise
{

    start(){

        console.log('Promise start');
        let promise=new Promise((resolev,reject)=>{
            setTimeout(()=>{
                resolev();
            },20000)
        })
        return promise;
    };
}

let u=new DoTaskPromise();
    u.start().then(()=>{
    console.log('Promise  end');
});

class DoTask
{
    //开启异步
    start(callback){
        console.log('callback start!!!');
        this.callback=callback;
        setTimeout(this.end.bind(this),10000);
    }

    end(){
        console.log('callback end!!!');
        if(this.callback)
        {
            this.callback();
        }

    }
}
 let v=new DoTask();
 v.start(()=>{
    console.log('callback  finish!!!');
 });

//8.异步操作 callback(); Promise class DoTaskPromise { start(){ console.log('Promise start'); let promise=new Promise((resolev,reject)=>{ setTimeout(()=>{ resolev(); },20000) }) return promise; }; } let u=new DoTaskPromise(); u.start().then(()=>{ console.log('Promise end'); }); class DoTask { //开启异步 start(callback){ console.log('callback start!!!'); this.callback=callback; setTimeout(this.end.bind(this),10000); } end(){ console.log('callback end!!!'); if(this.callback) { this.callback(); } } } let v=new DoTask(); v.start(()=>{ console.log('callback finish!!!'); });

本人第一次写博客,以上内容全来自己手写,如果想交流可以加入:石家庄ReactNative交流群 526955818

react配置之浅谈的更多相关文章

  1. Linux CentOS下MySQL的安装配置之浅谈

    前期必备安装:VMware虚拟机,CentOS镜像[注意:Linux下使用CentOS   MySQL是不用在官网下载的,只需要配置就OK了] 下面开始正式操作: //CentOS安装MySQL之浅谈 ...

  2. mysql配置优化浅谈(一)

    MySQL对于web架构性能的影响最大,也是关键的核心部分.MySQL的设置是否合理优化,直接影响到web的速度和承载量!同时,MySQL也是优化难度最大的一个部分,不但需要理解一些MySQL专业知识 ...

  3. 浅谈配置chrome浏览器允许跨域操作的方法

    浅谈配置chrome浏览器允许跨域操作的方法 一:(Lying人生感悟.可忽略) 最近有一天,对着镜子,发现满脸疲惫.脸色蜡黄.头发蓬松.眼神空洞,于是痛诉着说生活的不如意,工作没激情,工资不高,一个 ...

  4. MySql主从配置实践及其优势浅谈

    MySql主从配置实践及其优势浅谈 1.增加两个MySQL,我将C:\xampp\mysql下的MYSQL复制了一份,放到D:\Mysql2\Mysql5.1 修改my.ini(linux下应该是my ...

  5. 浅谈React

    浅谈react react是什么?其官网给出了明确定义:A JavaScript library for building user interfaces,一个用于构建用户界面的JavaScript库 ...

  6. 浅谈React数据流管理

    引言:为什么数据流管理如此重要?react的核心思想就是:UI=render(data),data就是我们说的数据流,render是react提供的纯函数,所以用户界面的展示完全取决于数据层.这篇文章 ...

  7. 浅谈Kotlin(一):简介及Android Studio中配置

    浅谈Kotlin(一):简介及Android Studio中配置 浅谈Kotlin(二):基本类型.基本语法.代码风格 浅谈Kotlin(三):类 浅谈Kotlin(四):控制流 前言: 今日新闻:谷 ...

  8. 浅谈Spring中的Quartz配置

    浅谈Spring中的Quartz配置 2009-06-26 14:04 樊凯 博客园 字号:T | T Quartz是一个强大的企业级任务调度框架,Spring中继承并简化了Quartz,下面就看看在 ...

  9. 【转】浅谈React、Flux 与 Redux

    本文转自<浅谈React.Flux 与 Redux>,转载请注明出处. React React 是一个 View 层的框架,用来渲染视图,它主要做几件事情: 组件化 利用 props 形成 ...

随机推荐

  1. 【Xilinx-VDMA模块学习】-01- VDMA IP的GUI配置介绍

    使用的是Vivado 2015.4,XC7Z020, AXI Video Direct Memory Acess(6.2). 在我的系统中,GUI配置图片如下:(其实和默认配置没有太大区别) 下面介绍 ...

  2. 用scala实现一个基于TCP Socket的快速文件传输程序

    这是用scala实现的一个简单的文件传输程序. 服务端 package jpush import java.io.{DataInputStream, File, FileOutputStream} i ...

  3. Unity 压缩texture

    当我们往服务器保存图片时 并不会仅仅保留原图 一般会另外保存一张缩略图 当加载文件夹时只加载缩略图 当在点击缩略图打开图片时 再加载原缩略图 以节省时间和内存 下面以将屏幕截图保存到服务器为例 将屏幕 ...

  4. TIMESTAMP和DATETIME哪个好

    日期范围 TIMESTAMP 支持从'1970-01-01 00:00:01′ 到 '2038-01-19 03:14:07′ UTC. 这个时间可能对目前正在工作的人来说没什么问题,可以坚持到我们退 ...

  5. jQuery内容过滤器

    jQuery内容过滤器 <h1>this is h1</h1> <div id="p1"> <h2>this is h2</h ...

  6. doubango(3)--协议栈的启动过程

    协议栈启动的上层接口 对于Doubango中得sip协议栈,是通过SipStack类粘合上层代码与底层代码的,该类定义在SipStack.h中,实现在SipStack.cxx中.当构造好一个SipSt ...

  7. Bootstrap入门(九)组件3:按钮组

    Bootstrap入门(九)组件3:按钮组   先引入本地的CSS文件和JS文件(注:1.bootstrap是需要jQuery支持的.2.需要在<body>当中添加) <link h ...

  8. 自制基于HMM的中文分词器

    不像英文那样单词之间有空格作为天然的分界线, 中文词语之间没有明显界限.必须采用一些方法将中文语句划分为单词序列才能进一步处理, 这一划分步骤即是所谓的中文分词. 主流中文分词方法包括基于规则的分词, ...

  9. JavaScript字符集编码与解码

    一.字符集 1)字符与字节(Character) 字符是各种文字和符号的总称,包括乱码:一个字符对应1~n个字节,一字节对应8位,每位用0或1表示. 2)字符集(Character Set) 字符集是 ...

  10. Scala入门笔记二

    [TOC] 标识符 可用的字符 处理括号类字符,分隔符之外,其他所有的可打印的ASCII字符,如字母,数字,下划线和美元符号($)均可出现在Scala标识符中 插入符包括了(,) [,] {,and} ...