- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
好吧,我想做一些看似简单的事情:从继承的函数中调用基本方法。我在 babel 的 create-react-scripts
环境中执行此操作,该脚本看起来像(尽可能小):
import * as React from react;
class base {
constructor() {
this.data = 'blah';
}
foo = () => {
console.log(this.data);
}
}
class child extends base{
constructor() {
super();
this.childData = 'ok';
}
foo = () => {
super.foo();
console.log(this.childData);
}
}
const Main = class Main extends React.Component {
constructor(props) {
super(props);
const c = new child();
c.foo();
}
render() {
return <div>test</div>
}
}
现在这立即提示(只有第一个错误似乎包含信息):
Uncaught TypeError: Cannot read property 'call' of undefined
The above error occurred in the <Main> component:
in Main (at App.js:62)
in div (at App.js:62)
in Route (at App.js:62)
in Router (at App.js:61)
in MuiPickersUtilsProvider (at App.js:60)
in Provider (at App.js:59)
in ThemeProvider (at App.js:58)
in div (at App.js:58)
in App (at src/index.js:7)
Consider adding an error boundary to your tree to customize error handling behavior.
检查显示这是由于 child.foo
函数中的 super.foo()
行导致的。
这里发生了什么?我如何从子 foo 中调用 base 的 foo?
list -g create-react-app
└── create-react-app@2.0.3
"devDependencies": {
"@babel/cli": "^7.4.4",
"@babel/core": "^7.4.5",
"babel-preset-flow": "^6.23.0",
"flow-bin": "^0.99.0",
},
最佳答案
看起来问题出在箭头函数上。
问题的详细信息在这里:
Arrow Functions in Class Properties Might Not Be As Great As We Think
Arrow functions in class properties won’t be in the prototype and we can’t call them with super.
同时绑定(bind)每一种被认为是不好的做法的方法。它可能会导致大规模的性能问题。只绑定(bind)需要的似乎更好。
关于javascript - 如何调用继承类中的基方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57173413/
经过几个小时的(重新)搜索,我无法想出普通抽象类和使用模板模式之间的可解释区别。 我唯一看到的是: 使用抽象类时,您需要实现所有方法。但是在使用模板方法时,您只需要实现这两个抽象方法。 有人可以向我解
我正在尝试实现一种算法,该算法可找到以下形状给出的外多边形的每个单独边的对应区域。也就是说,1,2 边的相应区域是 [1,6,7,8,2],2,3 边的区域是 [2,8,3] 等等,CCW 或 CW
我正在尝试在派生 self 的 BaseController 类的任何 Controller 上自动设置一个属性。这是我的 Application_Start 方法中的代码。 UnitOfWork 属
我正在使用 mgcv 包通过以下方式将一些多项式样条拟合到一些数据: x.gam smooth$knots [1] -0.081161 -0.054107 -0.027053 0.000001
考虑以下代码: void foo(){ ..... } int main() { int arr[3][3] ; char string[10]; foo();
本书The c++ programming language有这个代码: class BB_ival_slider : public Ival_slider, protected BBslider {
是否有一个 package.json 属性可用于指定模块解析应启动的根文件夹? 例如,假设我们在 node_modules/mypackage/src/file1 中有一个安装。我们要导入的所有文件都
我正在尝试使用聚合函数来实现与 SQL 查询相同的结果: 查询语句: sqldf(" SELECT PhotoID, UserID,
我正在比较使用 LOESS 回归的两条线。我想清楚地显示两条线的置信区间,我遇到了一些困难。 我尝试过使用各种线型和颜色,但在我看来,结果仍然是忙碌和凌乱。我认为置信区间之间的阴影可能会使事情变得更清
给定这段代码 public override void Serialize(BaseContentObject obj) { string file = ObjectDataStoreFold
我正在构建某种工厂方法,它按以下方式将 DerivedClass 作为 BaseClass 返回: BaseClass Factory() { return DerivedClass(); }
当重写 class delegation 实现的接口(interface)方法时,是否可以调用通常从重写函数中委托(delegate)给的类?类似于使用继承时调用 super 的方式。 来自docum
我有一个基类 fragment (如下所示)。我在其他 3 个 fragment 类中扩展了此类,每个类都共享需要在这 3 个 fragment 中访问的相同 EditText。因此,我在基类中设置了
如何在不加载额外库的情况下在 R 中计算两个排列之间的 Kendall tau 距离(又名冒泡排序距离)? 最佳答案 这是一个 O(n.log(n)) 的实现,在阅读后拼凑而成,但我怀疑可能有更好的
情况 我创建了一个具有国际化 (i18n) 的 Angular 应用程序。我想在子域中托管不同的版本,例如: zh.myexample.com es.myexample.com 问题 当我使用命令 n
std::is_base_of 之间的唯一区别和 std::is_convertible是前者在 Base 时也成立是 私有(private)或 protected Derived 的基类.但是,您何
我创建了一个名为 baseviewcontroller 的父类(super class) uiviewcontroller 类,用于包含大多数应用屏幕所需的基本 UI。它包括一个自定义导航栏和一个“自
我是一名优秀的程序员,十分优秀!