日常积累程序员技术干货

react基础入门:(一)原生JS基础测试

2019-01-17  本文已影响57人  8b6370ea271c

原文链接:react基础入门:(一)原生JS基础测试


以下问题都是以es6为基础

一 基础

字符串、数字、布尔、数组、对象、Null、Undefined

var、const、let

const arr = [1, "a", new Date()];
Array操作方法
const obj = {
    age: 20,
    name: 'lily'
};
Object操作方法 全局函数及变量 Map操作方法 Set操作方法
const { age, name } = {
    age: 20,
    name: 'lily',
    sex: '女'
};
console.info({age, name}); // {age: 20, name: "lily"}

二 函数

const sayHello = (name) => {
    console.info(`你好:${name}`);
};

sayHello('lily'); // 你好:lily
// 1
const sayHello = (name = 'def') => {
    console.info(`你好:${name}`);
};
sayHello(); // 你好:def
sayHello('lily'); // 你好:lily

// 2
const sayHello = ({ name = 'def' } = {}) => {
    console.info("你好:" + name);
};

sayHello(); // 你好:def
sayHello({ name: 'lily' }); // 你好:lily
console.info(1);
setTimeout(() => {
    console.info(2);
}, 0);
console.info(3);

// 输出结果:1 3 2
const callback = (name) => {
    console.info('callback 执行');
    return name;
};

const exec = (name, nameFunc) => {
    console.info(`exec 执行`);
    console.info(`你好:${nameFunc(name)}`);
};

exec('lily', callback); // 你好:lily
const nameFunc = (name) => {
    console.info(`outFunc 执行`);
    
    return (age) => {
        console.info(`姓名:${name},年龄:${age}`);
    };
};

nameFunc('lily')(20); // 姓名:lily,年龄:20
Promise常用方法

三 面向对象

class User {

    constructor(name) {
        console.info(`User 构造函数执行,创建 User 对象 name=${name}`);
    }

};

const user = new User('lily'); 

// User 构造函数执行,创建 User 对象 name=lily
class Human {

    constructor(age) {
        console.info(`Human 构造函数执行,创建 Human 对象 age=${age}`);
    }

}

class User extends Human {

    constructor(age, name) {
        super(age);
        console.info(`User 构造函数执行,创建 User 对象 name=${name}`);
    }

};

const user = new User(20, 'lily');

// Human 构造函数执行,创建 Human 对象 age=20
// User 构造函数执行,创建 User 对象 name=lily

四 模块

export const sayHello = (name) => {
    console.info(`你好:${name}`);
};

export const obj = {
    age: 20,
    name: 'lily'
};
// 1
import module1 from './module1';

console.info(module1);

// 2
import { sayHello, obj } from './module1';

console.info(sayHello('lily'), obj);

五 网络

fetch(url, options).then(function(response) {
  // handle HTTP response
}, function(error) {
  // handle network error
});

// 例子
fetch(url, {
  method: "POST",
  body: JSON.stringify(data),
  headers: {
    "Content-Type": "application/json"
  },
  credentials: "same-origin"
}).then(function(response) {
  response.status     //=> number 100–599
  response.statusText //=> String
  response.headers    //=> Headers
  response.url        //=> String

  return response.text()
}, function(error) {
  error.message //=> String
})

扫码关注有惊喜
上一篇下一篇

猜你喜欢

热点阅读