How Does Flask Url_for Work?
Solution 1:
Flask does not use the module name for the endpoint. It simply defaults to the function name.
If you register two different functions with the same name (say, in two different modules), an AssertionError
exception is raised:
raise AssertionError('View function mapping is overwriting an '
'existing endpoint function: %s' % endpoint)
You can specify an explicit endpoint name in such cases:
@app.route('/', endpoint='alt_homepage')
def homepage():
pass
See the @Flask.route()
documentation:
endpoint – the endpoint for the registered URL rule. Flask itself assumes the name of the view function as endpoint
When you register a view (with the @app.route()
decorator), the endpoint name is determined (unless you set one explicitly) and stored with the route registration. url_for()
uses the route registration to find all routes registered against that name and finds the one best fitting the parameters you also passed to url_for()
.
Post a Comment for "How Does Flask Url_for Work?"