react 修改

  {/*修改弹框*/}
                        <Modal
                            visible={this.state.upvisible}
                            title="添加任务信息"
                            footer={null}
                            onCancel={this.hideModal}
                        >
                            <Form
                                style={{marginLeft:'-12px'}}
                                labelCol={{ span: 6 }}
                                wrapperCol={{ span: 14 }}
                                layout="horizontal"
                                onFinish={this.onFinish}
                                initialValues={{
                                    task_name:this.state.task_name,
                                    task_type:this.state.task_type,
                                    task_reward:this.state.task_reward,
                                    task_time:this.state. task_time,
                                    task_rules:this.state.task_rules,
                                }}
                            >
                                <Form.Item name='task_name' label="任务名称">
                                    <Input  placeholder="large size"  />
                                </Form.Item>
                                <Form.Item name='task_type' label="Select">
                                    <Select>
                                        <Option value="新手任务" >新手任务</Option>
                                        <Option value="日常任务" >日常任务</Option>
                                        <Option value="活动任务" >活动任务</Option>
                                    </Select>
                                </Form.Item>
                                <Form.Item name='task_reward' label="任务奖励">
                                    <Input  placeholder="large size" />
                                </Form.Item>
                                <Form.Item name='task_time' label="有效期">
                                    <RangePicker
                                        locale={locale}/>
                                </Form.Item>
                                <Form.Item name='task_rules' label="任务规则">
                                    <TextArea
                                        placeholder="任务规则"
                                        autoSize={{ minRows: 3, maxRows: 5 }}
                                    />
                                </Form.Item>
                                <Form.Item style={{margin:'20px 0 0 120px '}} >
                                    <Button key="back" onClick={this.handleCancel}>
                                        取消
                                    </Button>
                                    <Button key="submit" type="primary" htmlType="submit"  onClick={this.handleOk}>
                                        提交
                                    </Button>
                                </Form.Item>

                            </Form>
                        </Modal>




 constructor(prors){
        super(prors)
        this.state={
            upvisible: false,
            task_no:0,
            task_name:'',
            task_type:'',
            task_reward:'',
            task_time:[moment('', dateFormat)  ,moment('', dateFormat)] ,
            task_rules:'',
            task_isup:0,
        }
    }

     弹框显示
    showModal = () => {
        this.setState({
            upvisible: true,
        });
    };
    hideModal = () => {
        this.setState({
            upvisible: false,
        });
    };

     // 点击确认
    handleOk = () => {
        this.setState({
            upvisible: false,
        });

    };

    // 点击取消
    handleCancel = ()=> {
        this.setState({
            upvisible: false,
        });
    };
 // 编辑
    update(text,record,index){
        this.setState({
            upvisible: true,
            task_no:record.task_no,
            task_name:record.task_name,
            task_type:record.task_type,
            task_reward:record. task_reward,
            task_time:[moment(record.task_starttime, dateFormat)  ,moment(record.task_endtime, dateFormat)] ,
            task_rules:record. task_rules,
            task_isup:record.task_isup,
        });
    }

    // 获取编辑表单数据并发起请求
    onFinish = values => {
        axios.post(api.task.updata,{
            task_no: this.state.task_no,
            task_name: values.task_name,
            task_type:values. task_type,
            task_reward:values.task_reward,
            task_isup:this.state.task_isup,
            task_starttime:values.task_time[0]._i,
            task_endtime:values.task_time[1]._i,
            task_rules:values.task_name
        }).then((res)=>{
            if (res.data.code==200){
                this.success(res.data.msg)
            }
        }).catch((err)=>{
            console.log(err)
        })
    }

上述写法会出现Form 的值不会动态改变

解决方法:
Modal窗口我们都有应用一个变量Visible来控制是否显示, 我们只要利用这个值得变化就可以实现Modal组件的重新挂载了。

但是要在把值设置完成后再改变visible的值为true

{
    Visible && <Modal ....../>
}


 // 编辑
    update(text,record,index){
        new Promise((resolve)=>{
        this.setState({
          upvisible: true,
          task_no:record.task_no,
          task_name:record.task_name,
          task_type:record.task_type,
          task_reward:record. task_reward,
          task_time:[moment(record.task_starttime, dateFormat)  ,moment(record.task_endtime, dateFormat)] ,
          task_rules:record. task_rules,
          task_isup:record.task_isup,
        });
        resolve()
      }).then(()=>{
          this.setState({
            istrue:true
          })
      })
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269