WithRouter的作用和一个简单应用
作用:把不是通过路由切换过来的组件中,将react-router 的 history、location、match 三个对象传入props对象上
React.lazy来实现React组件的懒加载
JavaScript call() 方法
call() 方法是预定义的 JavaScript 方法。
它可以用来调用所有者对象作为参数的方法。
通过 call(),您能够使用属于另一个对象的方法。
本例调用 person 的 fullName 方法,并用于 person1:
实例
var person = {
fullName: function() {
return this.firstName + " " + this.lastName;
}
}
var person1 = {
firstName:“Bill”,
lastName: “Gates”,
}
var person2 = {
firstName:“Steve”,
lastName: “Jobs”,
}
person.fullName.call(person1); // 将返回 “Bill Gates”
JavaScript apply() 方法
apply() 方法与 call() 方法非常相似:
在本例中,person 的 fullName 方法被应用到 person1:
实例
var person = {
fullName: function() {
return this.firstName + " " + this.lastName;
}
}
var person1 = {
firstName: “Bill”,
lastName: “Gates”,
}
person.fullName.apply(person1); // 将返回 “Bill Gates”
call() 和 apply() 之间的区别
不同之处是:
call() 方法分别接受参数。
apply() 方法接受数组形式的参数。
如果要使用数组而不是参数列表,则 apply() 方法非常方便。