Let’s say you have a input field and routes configured:
How can you avoid that the user navigates to a route if the inputfield contains unsaved text? I made a few tries to find a solution for that but did not found anything. So here is what I have done to solve this problem.
Find the full runnable example here: Click me!
Solution
First, define a new global function:
let isRouteChangeBlocked: boolean = false;
export function blockRouteChange(set?: boolean): boolean {
if (arguments.length == 1) {
isRouteChangeBlocked = !!set;
return isRouteChangeBlocked;
}
return isRouteChangeBlocked;
}
Then use it to set the flag after the user make some input:
@Watch("input")
private inputChange(to: string) {
if (to && to.length > 0) {
blockRouteChange(true);
} else {
blockRouteChange(false);
}
}
After a successful saving, reset the flag:
private save() {
blockRouteChange(false);
alert("saved");
}
Now replace the router’s push
function:
const originalPush = VueRouter.prototype.push;
VueRouter.prototype.push = function(location: RawLocation) {
if (blockRouteChange()) {
if (confirm("There are unsaved changes, do you want to continue?")) {
blockRouteChange(false);
return originalPush.call(this, location) as any;
}
return;
}
return originalPush.call(this, location) as any;
};
Result
Here is what I got:
Conclusion
This workaround works really well but I’m wondering whether there isn’t a better possibility? Do you know how this can be achieved using a native solution? Maybe I just was not clever enough to type in the correct search terms into google ? Just let me know.