export const go2Page=(url,title:string,handlerBack?:(flag:number,data?:any)=>void,isPage:boolean=true,size:'sm'|'lg'|"xlg"='lg')=>{ if(isPage){ history.push(url); return; } const all=[].concat(routerItemArray); const one= all.find((v,i)=>{ if(v.path.indexOf(':')!==-1){ const m1=new RegExp(v.path.replace(':id','\\w?')); return m1.test(url); }else{ return v.path===url; } }); const raw= one!=null?one.element:<div>没有找到</div>; const A :any=()=> (<div>{raw}</div>); return RvModal.open({ width: size==='sm'?400:(size==='lg'? 800:(size==='xlg'?1120:1200)), title: title||'查看', footer: null, onCancel: (args) => null, }, <A isPage={false} routePath={url} handlerBack={handlerBack||null}/>); } dialog= go2Page('/examine-flow-impower/'+value?.id,"审批流程授权",goBack,false);前端是这样跳转到修改页面的为什么 <Button onClick={() => {props.handlerBack?.bind(this, 0)}} style={{ marginLeft: "20px" }}>取消</Button> 取消没有反应
时间: 2024-04-13 11:24:55 浏览: 165
根据你提供的代码,我注意到你在go2Page
函数中使用了history.push(url)
来进行页面跳转。这是一种常见的前端路由操作,用于将用户导航到指定的URL。
至于取消按钮没有反应的问题,可能存在以下几个原因:
未正确绑定
handlerBack
函数:请确保在调用go2Page
函数时,正确地传递了handlerBack
函数作为参数。并且在取消按钮的onClick
事件中,正确地调用了props.handlerBack?.bind(this, 0)
。如果未正确绑定函数,取消按钮点击后将不会触发任何响应。props.handlerBack
函数没有被正确传递:请检查调用go2Page
函数时是否正确地传递了handlerBack
函数作为参数。handlerBack
函数中存在其他问题:请确保在handlerBack
函数中没有其他错误或逻辑问题,导致取消按钮点击后无法触发期望的操作。
另外,需要注意的是,你在取消按钮上使用了props.handlerBack?.bind(this, 0)
来绑定事件。这里使用了可选链操作符(?.
),它会在props.handlerBack
存在时才执行后续的.bind(this, 0)
。请确保你在使用可选链操作符时,props.handlerBack
确实存在。
如果以上检查都没有解决问题,请提供更多相关代码和错误信息,以便我更好地帮助你解决这个问题。