javascript - antdesign底层弹出个confirmModal。怎么获取底层的this?
问题描述

showConfirm() {//弹出确认对话框confirm({ title: ’当前总计应收金额为’+this.state.allReceivablePrice+’元’,//这里能得到值!!!! // content: ’some descriptions’, okText: ’确认回款’, cancelText: ’取消’, onOk() {const {allSelectOrder}=this.state;if (allSelectOrder.length==0){ message.error(’订单Id不能为空’); return;}else { this.setState({loading: true}); $.ajax({url: API.flow,type: ’post’,dataType: ’json’,data: JSON.stringify(allSelectOrder),contentType: ’application/json;charset=UTF-8’,success: ()=> { this.setState({loading: false, }); message.success(’添加收款记录成功!’); this.refreshData();},error: (data)=> { Modal.error({title: data.responseJSON.msg }); this.setState({ loading: false });} })} }, onCancel() { },}); },
这个this我怎么获取不到呢,都加了bind了报错:
PaymentCollection.jsx:329 Uncaught TypeError: Cannot read property ’state’ of undefined
问题解答
回答1:你ajax的success和error都没有bind。注意看报错信息的位置。
showConfirm() {//弹出确认对话框 confirm({title: ’当前总计应收金额为’+this.state.allReceivablePrice+’元’,//这里能得到值!!!!// content: ’some descriptions’,okText: ’确认回款’,cancelText: ’取消’,onOk: () => { const {allSelectOrder}=this.state; if (allSelectOrder.length==0){message.error(’订单Id不能为空’);return; }else {this.setState({loading: true});$.ajax({ url: API.flow, type: ’post’, dataType: ’json’, data: JSON.stringify(allSelectOrder), contentType: ’application/json;charset=UTF-8’, success: ()=> {this.setState({ loading: false,});message.success(’添加收款记录成功!’);this.refreshData(); }, error: (data)=> {Modal.error({ title: data.responseJSON.msg});this.setState({ loading: false }); }}) }},onCancel() {}, });},
准确来说是onOk函数的this环境已经丢失了。;
回答2:谢邀。
-----分割线----
在showConfirm外面定义个一个_this,然后用_this替换this即可。
或者你在外面let bindsuc = function(data){}.bind(this);//然后里面...success:bindsuc,//error同理...
相关文章:
1. redis sentinel怎么跑守护进程以及日志记录位置的?2. Python异常退出时保存进度?3. javascript - sublime快键键问题4. 前端 - 这段代码一直生效不了,查半天因为 top: 0px; 分号后一个隐藏的东西,也不是占位符...删了就可以生效,这是什么情况。。5. 使用git管理webpack的代码时多人怎么协作?一般托管哪些文件?6. django - Nginx uwsgi 进程问题7. javascript - 求助关于js正则问题8. html5 - ElementUI table中el-table-column怎么设置百分比显示。9. angular.js - 百度爬虫如何处理“#”符号?10. php - 数据库存图片,是存图片名称?还是存图片路径??

网公网安备