- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
你能解释一下为什么 react 状态在函数handleFinishChange
中可见,而在validationFinishTime
中看不到。两者都传输到组件InputFieldForm
。当 input
中的字段发生更改时,执行此代码会导致 Uncaught TypeError: Cannot read property 'finish' of undefined
in validationFinishTime
。 p>
组件ShiftFormAdmin
import React from 'react'
import {browserHistory} from 'react-router'
import Loading from './../form/loading.jsx'
import message from './../../constants/message';
import style from './../../constants/style';
import ErrorInformation from '../form/ErrorInformationForm.jsx';
import InputFieldForm from '../form/InputFieldForm.jsx';
import SelectFieldForm from '../form/SelectFieldForm.jsx';
import urls from './../../constants/urls'
import moment from 'moment';
export default class ShiftFormAdmin extends React.Component{
constructor(props){
super(props)
this.state = {
box : {value : '', isValid : true},
washerMan : {value : "", isValid : true},
finish : {value : this.props.finish, isValid : true},
start : '',
availableWasherManList : [],
boxCount : this.props.initData.boxCount,
errorDisplay : style.DISPLAY_NONE,
errorMessage : message.MESSAGE_DEFAULT_ERROR,
isWasherMansDownloaded: false,
isCurrentTimeDownloaded : false
}
this.handleSubmit = ::this.handleSubmit
this.handleBoxChange = ::this.handleBoxChange
this.downloadWasherMans = ::this.downloadWasherMans
this.filterWasherMan = ::this.filterWasherMan
this.downloadServerTime = ::this.downloadServerTime
this.setStartTime = :: this.setStartTime
this.handleFinishChange = ::this.handleFinishChange
}
handleFinishChange(e){
this.setState({
finish : {
value : e.target.value,
isValid : true
}
})
}
validationFinishTime(value){
let result = false;
console.log(this.state.finish.value)
return result;
}
render(){
let data = <Loading/>
let boxCount = [];
for(let i=1; i<=this.state.boxCount; i++){
boxCount.push(i);
}
if(this.state.isWasherMansDownloaded && this.state.isCurrentTimeDownloaded) {
data =
<form className="form-horizontal" onSubmit={this.handleSubmit} id="shiftForm">
<InputFieldForm
title="finish:"
name="finish"
onChange={this.handleFinishChange}
maxLength={5}
defaultValue={this.state.finish.value}
validation={this.validationFinishTime}
errorMessage="error"/>
<div className="form-group">
<div className="col-sm-offset-2 col-sm-10">
<button type="submit" className="btn btn-success"> ADD
</button>
</div>
</div>
</form>
}
return(
<div className="form-general">
{data}
</div>
)
}
}
类FormInputField
export default class FormInputField extends React.Component{
constructor(props) {
super(props);
this.state = {
value : this.props.defaultValue ? this.props.defaultValue : '',
errorDisplay : st.DISPLAY_NONE,
errorMessage : msg.MESSAGE_DEFAULT_ERROR,
}
this.validation = this.validation.bind(this);
this.handleChange = this.handleChange.bind(this);
this.handleBlur = this.handleBlur.bind(this);
}
handleChange(e){
let valid = this.validation(e.target.value.trim());
if (this.props.onChange){
this.props.onChange(e, valid)
}
}
validation(value){
let errorDisplay = st.DISPLAY_NONE;
let errorMessage = '';
let valid = true;
if (this.props.notShow != true) {
if (this.props.required && jQuery.isEmptyObject(value)) {
errorMessage = msg.MESSAGE_FIELD_IS_REQUIRED;
errorDisplay = st.DISPLAY_BLOCK;
valid = false;
} else if (this.props.maxLength && value.trim().length > this.props.maxLength) {
valid = false;
errorMessage = this.props.maxLength + msg.MESSAGE_MAX_LENGTH;
errorDisplay = st.DISPLAY_BLOCK;
} else if (this.props.validation && !this.props.validation(value.trim())) {
valid = false;
errorDisplay = st.DISPLAY_BLOCK;
errorMessage = this.props.errorMessage;
}
}
this.setState({
value : value,
errorDisplay : errorDisplay,
errorMessage : errorMessage
})
return valid;
}
handleBlur(e) {
this.validation(e.target.value.trim());
}
render(){
let data;
let readonly = undefined;
if (this.props.readonly){
readonly = true
}
if(this.props.notShow != true){
data = <div className="form-group">
<label htmlFor = {this.props.name} className="col-sm-2 control-label">{this.props.title}</label>
<div className="col-sm-10">
<input name={this.props.name}
type="text" className="form-control"
id={this.props.name}
placeholder={this.props.placeholder}
value={this.state.value}
onChange={this.handleChange}
onBlur={this.handleBlur}
disabled={this.props.disabled}
readOnly = {readonly}
/>
</div>
</div>
}
return(
<div>
{data}
</div>
)
}
}
最佳答案
<小时/>Suggested solution: Bind your event handler to the component context/scope:
(same as other statements in your constructor, but I haven't used before)
this.validationFinishTime = ::this.validationFinishTime
OR (the way I normally do this; again, within the constructor):
this.validationFinishTime = this.validationFinishTime.bind(this);
建议背后的理由:
这里有点猜测,因为我以前没有见过这个语法( this.handleFinishChange = ::this.handleFinishChange
),但我猜测它绑定(bind)了 this
组件的上下文。到方法所以方法this.handleFinishChange
可以引用类似 this.setState
的内容和this.state
.
validationFinishTime
没有绑定(bind)到组件上下文,因此当它引用 this.state.finish
时,没有提及this.state
因为this
指的是它被调用的上下文:这是 <InputFieldForm/>
上“验证”的内联事件上下文 .
关于javascript - js 中函数的上下文可见性 (React.js),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40958685/
出现以下错误 Network access for Distributed Transaction Manager (MSDTC) has been disabled. Please enable D
在调试应用程序时出现以下错误。 The CLR has been unable to transition from COM context 0x3b2d70 to COM context 0x3b2
在 GAE Go 中,为了记录,我们需要使用 appengine.NewContext(r) 创建一个新的上下文,它返回 context.Context。 如何使用此上下文在请求范围内设置/获取变量?
我想使用 Puppeteer 从放置在页面上 iframe 内的选择器中获取数据,该页面在与其父框架域不同的域上运行。因此,我不是任何域的所有者 - 无法使用 frame.postMessage。 试
我正在尝试获取可用的应用程序上下文并想切换到 webview 上下文,但 appium 仅获取 Navive App。 应用程序还启用了 WebView。 Appium 版本:1.10.1 Chrom
这个问题在这里已经有了答案: How to fix this nullOk error when using the flutter_svg package? (7 个回答) 7 个月前关闭。 当我尝
我观看了关于 Core Data 的 2016 WWDC 视频并查看了各种教程。我见过使用 Core Data Framework 创建对象以持久保存到 managedObjectContext 中的
这是代码 obj = { a: 'some value'; m: function(){ alert(this.a); } } obj.m(); 结果是'som
我正在尝试做类似的事情 $(".className").click(function() { $(this).(".anotherClass").css("z-index","1");
var User = { Name: "Some Name", Age: 26, Show: function() { alert("Age= "+this.Age)}; }; fun
我目前正在使用我见过的常见 Context 模式,它允许子组件通过传递修饰函数来更新父组件的状态(即 Provider)通过共享的 Context。 我遇到的问题是,修改函数只引用原始状态,不引用最新
有没有办法让 React Context类型安全与流类型? 例如: Button.contextTypes = { color: React.PropTypes.string }; 最佳答案 不幸
我想知道是否有一种方法可以为不同的功能使用不同的上下文类。 我希望有一个功能使用 MinkExtensions 进行浏览器测试,另一个功能使用和 HTTP 客户端(如 Guzzle)进行 API 测试
我有这个配置文件 apiVersion: v1 clusters: - cluster: server: [REDACTED] // IP of my cluster name: stag
我在实现非抢先式调度时遇到了用于初始化TCB的代码。 typedef struct TCB_t { struct TCB_t *next; struct TCB_t
我想将一个函数设置为数组中每个元素的属性,但使用不同的参数调用它。我想我会使用匿名函数来解决它: for ( var i = 0; i < object_count; i++ ) { obje
这个问题已经有答案了: How to access the correct `this` inside a callback (15 个回答) 已关闭 7 年前。 我正在做一些练习,但我在管道方法中丢
我正在尝试通过 Java 和 Android Studio 学习和制作 Android 应用程序。我对Java的了解程度是两年前几个小时的youtube学习和大学基础类(class)。不过我确实知道如
我在(这个)上遇到了问题。错误ImageView无法应用。我在 fragment 类中执行此代码。 ViewFlipper v_flipper; @Nullable @Override public
我想使用 openGL 的某些功能,但与渲染视觉内容无关。有没有办法在没有任何依赖性的情况下创建它(不是对 Windows,也不是某些包[SDL,SFML,GLUT])?只允许使用没有外部库的库,就像
我是一名优秀的程序员,十分优秀!