react配置之浅谈
//复习 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配置之浅谈的更多相关文章
- Linux CentOS下MySQL的安装配置之浅谈
前期必备安装:VMware虚拟机,CentOS镜像[注意:Linux下使用CentOS MySQL是不用在官网下载的,只需要配置就OK了] 下面开始正式操作: //CentOS安装MySQL之浅谈 ...
- mysql配置优化浅谈(一)
MySQL对于web架构性能的影响最大,也是关键的核心部分.MySQL的设置是否合理优化,直接影响到web的速度和承载量!同时,MySQL也是优化难度最大的一个部分,不但需要理解一些MySQL专业知识 ...
- 浅谈配置chrome浏览器允许跨域操作的方法
浅谈配置chrome浏览器允许跨域操作的方法 一:(Lying人生感悟.可忽略) 最近有一天,对着镜子,发现满脸疲惫.脸色蜡黄.头发蓬松.眼神空洞,于是痛诉着说生活的不如意,工作没激情,工资不高,一个 ...
- MySql主从配置实践及其优势浅谈
MySql主从配置实践及其优势浅谈 1.增加两个MySQL,我将C:\xampp\mysql下的MYSQL复制了一份,放到D:\Mysql2\Mysql5.1 修改my.ini(linux下应该是my ...
- 浅谈React
浅谈react react是什么?其官网给出了明确定义:A JavaScript library for building user interfaces,一个用于构建用户界面的JavaScript库 ...
- 浅谈React数据流管理
引言:为什么数据流管理如此重要?react的核心思想就是:UI=render(data),data就是我们说的数据流,render是react提供的纯函数,所以用户界面的展示完全取决于数据层.这篇文章 ...
- 浅谈Kotlin(一):简介及Android Studio中配置
浅谈Kotlin(一):简介及Android Studio中配置 浅谈Kotlin(二):基本类型.基本语法.代码风格 浅谈Kotlin(三):类 浅谈Kotlin(四):控制流 前言: 今日新闻:谷 ...
- 浅谈Spring中的Quartz配置
浅谈Spring中的Quartz配置 2009-06-26 14:04 樊凯 博客园 字号:T | T Quartz是一个强大的企业级任务调度框架,Spring中继承并简化了Quartz,下面就看看在 ...
- 【转】浅谈React、Flux 与 Redux
本文转自<浅谈React.Flux 与 Redux>,转载请注明出处. React React 是一个 View 层的框架,用来渲染视图,它主要做几件事情: 组件化 利用 props 形成 ...
随机推荐
- html 转义
function escapeHTML(n) { var t = document.createElement("div"), i = document.createTextNod ...
- Android开发:View的几种布局及实践
引言 View的布局显示方式有下面几种:线性布局(Linear Layout).相对布局(Relative Layout).表格布局(Table Layout).网格视图(Grid View).标签布 ...
- html <select> 用JS控制默认选中项
<html> <head> <!--禁止页面缓存--><meta http-equiv="content-type" content=&q ...
- Unity3D在NGUI中使用mask
过程是这样的:最近一直想做一个头像的mask效果,后来发现原来unity的mask需要用shader来写,网上找了不少资料,也能实现,不过大多数都是用render texture作为相机投影的text ...
- cgLib生成动态代理
package com.stono.cglib; import java.lang.reflect.Method; import net.sf.cglib.proxy.Enhancer; import ...
- C#综合揭秘——细说进程、应用程序域与上下文之间的关系
引言 本文主要是介绍进程(Process).应用程序域(AppDomain)..NET上下文(Context)的概念与操作.虽然在一般的开发当中这三者并不常用,但熟悉三者的关系,深入了解其作用,对提高 ...
- ubuntu开机自动关闭独显,使用集成显卡
我的本子是联想y470p-ise,因为是有双显卡,而ubuntu在开机后,双显卡默认是同时工作,会产生巨大的发热,导致很不爽.而且在ubuntu下基本我也不用独显,所以有开机关闭独显的需求. ubun ...
- Spring AOP中的动态代理
0 前言 1 动态代理 1.1 JDK动态代理 1.2 CGLIB动态代理 1.2.1 CGLIB的代理用法 1.2.2 CGLIB的过滤功能 2 Spring AOP中的动态代理机制 2.1 ...
- 用php进行md5解密的源码,亲测可用
<?php $md5 = "c1c95b382230eb9e27a60c4baceb5f2e"; $uid = "hhp-ImZRY"; $token = ...
- UE4里的渲染线程
记的上次看过UniRx里的源代码,说是参考微软的响应式编程框架,响应式编程里的一些理论不细说,只单说UniRx里的事件流里的事件压入与执行,与UE4的渲染线程设计有很多相同之处,如果有了解响应式编程相 ...