JS相关知识总结

2019-01-13  本文已影响0人  Alfred的记录本

扩展运算符 三个点...

扩展运算符( spread )是三个点(...)。它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列。

js中三种定义变量的方式const, var, let的区别

js删除数组中的元素delete和splice的区别

区别,第一种是点击回车手再调用,第二种是程序初始化时就调用

<SearchBar placeholder="Search" onSubmit={() => this.onSearchSubmit()} />
<SearchBar placeholder="Search" onSubmit={this.onSearchSubmit()} />

定义成员变量es6

this.aa = [];

button 还可以这么写

<button className="hover-button" >
                        <a href="#" style={{color:'#000'}}>back</a>
                </button>

函数参数

const headAndTail = (head, ...tail) => [head, tail];
headAndTail(1, 2, 3, 4, 5)
// [1,[2,3,4,5]]

变量的解构赋值

模板字符串

全局对象

扩展运算符

Promise

var promise = new Promise(function (resolve, reject) {
    // 2秒后置为接收状态
    setTimeout(function () {
        resolve('success');
    }, 2000);
});

promise
    .then(function (data) {
        // 上一个then()调用了resolve,置为fulfilled态
        console.log(`第一个then ${data}`);
        return '2';
    })
    .then(function (data) {
        // 此时这里的状态也是fulfilled, 因为上一步返回了2
        console.log(`第二个then ${data}`);  // 2

        return new Promise(function (resolve, reject) {
            reject('把状态置为rejected error'); // 返回一个rejected的Promise实例
        });
    }, function (err) {
        // error
    })
    .then(function (data) {
        /* 这里不运行 */
        console.log(`第三个then ${data}`);
        // ....
    }, function (err) {
        // error回调
        // 此时这里的状态也是fulfilled, 因为上一步使用了reject()来返回值
        console.log('出错:' + err); // 出错:把状态置为rejected error
    })
    .then(function (data) {
        // 没有明确指定返回值,默认返回fulfilled
        console.log('这里是fulfilled态');
    });

promise.then(function (data) {
    console.log(`与第一个同级的then ${data}`);  // 2
});

打印结果:

第一个then success
与第一个同级的then success
第二个then 2
出错:把状态置为rejected error
这里是fulfilled态

参考

Promise all 和 Promise race

参考链接

js对象

//这三种方法是等效的,没有任何区别
var obj = {1:"first"}
obj[2]="second";
obj["3"]="third";
function Person() {
  this.name=" 张三 "; // 定义一个属性 name
  this.sex=" 男 "; // 定义一个属性 sex
  this.age=22; // 定义一个属性 age
  this.say=function(){ // 定义一个方法 say()
    return "嗨!大家好,我的名字是 " + this.name + " ,性别是 " + this.sex + ",今年 " + this.age +"岁!";
  }
}
var zhangsan=new Person();
alert("姓名:"+zhangsan.name); // 使用“.”来访问对象属性
alert("性别:"+zhangsan.sex);
alert("年龄:"+zhangsan["age"]); // 使用“[ ]”来访问对象属性
alert(zhangsan.say);  // 使用“.”来访问对象方法

参考

function对象

数组操作

var arr = new Array(5);
arr[0] = "amy";
arr[1] = "elice";
arr[2] = "divi";
arr[3] = "lvy";
arr[4] = "marry";
arr.splice(1, 0, "willian");
console.log(arr);
//输出:amy,willian,elice,divi,lvy,在数组第一个位置增加一个元素,其值是"willian"

shift:原数组中删除头部元素

const squares = this.state.squares.slice();

对象操作

var target  = {a : 1}; //目标对象
var source1 = {b : 2}; //源对象1
var source2 = {c : 3}; //源对象2
var source3 = {c : 4}; //源对象3,和source2中的对象有同名属性c
Object.assign(target,source1,source2,source3);

真值 假值

js中除了:false,0,‘’(空字符串),null,undefinded,NAN ”六个是假值,其他的都是真值,这里需注意: '0'、'null'、'false'、{}、[]也都是真值。

表达式“&&”左右都是真值:返回右边的值
表达式“&&”左右有一个是假值是:返回假值
表达式“&&”左右都是假值:返回左边值
表达式“||”左右都是真值,返回左边操的值
表达式“||”左右有一个是假值,返回真值
表达式“||”左右都是假值,返回右边的值

上一篇 下一篇

猜你喜欢

热点阅读